变量作用域
JavaScript中的许多问题都来自于变量作用域:要么认为局部变量是全局的,要么用函数中的局部变量覆盖了全局变量。为了避免这些问题,最佳方案是根本没有任何全局变量。但是,如果你有一堆,那么你应该知道这些陷阱。
不用var关键字声明的变量是全局的。记住使用var关键字声明变量,防止变量具有全局作用域。在下面例子中,在函数中声明的变量具有全局变量,因为没有使用var关键字声明:
anonymousFuntion1 = function(){ globalvar = 'global scope'; //全局声明,因为“var”遗漏了 return localvar; }(); alert(globalvar); //弹出“global scope”,因为函数中的变量是全局声明
anonymousFuntion2 = function(){ var localvar = 'local scope'; //使用“var”局部声明 return localvar; }(); alert(localvar); //错误 “localvar未定义”。没有全局定义localvar
作为参数引进到函数的变量名是局部的。如果参数名也是一个全局变量的名字,像参数变量一样有局部作用域,这没有冲突。如果你想在函数中改变一个全局变量,这个函数有一个参数复制于这个全局变量名,记住所有全局变脸都是window对象的属性。
var myscope = "global"; function showScope(myscope){ return myscope; //局部作用域,即使有一个相同名字的全局变量 } alert(showScope('local'));
function globalScope(myscope){ myscope = window.myscope; //全局作用域 return myscope; } alert(globalScope(’local’));
你甚至可以在循环中声明变量:
for(var i = 0; i < myarray.length; i++){}
覆盖函数/重载函数
当你不止一次的声明一个函数时,这个函数的最后一次声明将覆盖掉该函数的所有前面版本且不会抛出任何错误或警告。这不同于其他的编程语言,像Java,你能用相同的名字有多重函数,只要它们有不同的参数:调用函数重载。在JavaScript中没有重载。这使得不能在代码中使用JavaScript核心部分的名字极其重要。也要当心包含的多个JavaScript文件,像一个包含的脚本文件可能覆盖另一个脚本文件中的函数。请使用匿名函数和名字空间。
(function(){ // creation of my namespace 创建我的名字空间 if(!window.MYNAMESPACE) { window['MYNAMESPACE'] = {}; } //如果名字空间不存在,就创建它 //这个函数仅能在匿名函数中访问 function myFunction(var1, var2){ //内部的函数代码在这儿 } // 把内部函数连接到名字空间上,使它通过使用名字空间能访问匿名函数的外面 window['MYNAMESPACE']['myFunction'] = myFunction; })(); // 圆括号 = 立即执行 // 包含所有代码的圆括号使函数匿名
这个例子正式为了实现解决上一个陷阱“变量作用域”的最佳方案。匿名函数详细内容请看《Javascript的匿名函数》。YUI整个库只有YAHOO和YAHOO_config两个全局变量,它正是大量应用匿名函数和命名空间的方法来实现,具体请看《Javascript的一种模块模式》。
出处:蓝色理想
责任编辑:bluehearts
上一页 JavaScript的陷阱 [2] 下一页 JavaScript的陷阱 [4]
◎进入论坛网页制作、WEB标准化版块参加讨论,我还想发表评论。
|