以前一直没注重到JScript中隐式变量声明和var显式变量声明的区别,虽然其间碰到一些问题,但没有引起太大的注重。直到今天写了几个函数,查了一下参考手册,觉得有必要改变一下传统隐式声明的习惯做法,以免带来不必要的麻烦。在手册中是这样描述“变量声明”的:
变量在脚本中的第一次出现是在声明中。变量在第一次用到时就设置于内存中,便于后来在脚本中引用。使用变量之前先进行声明。可以使用 var 要害字来进行变量声明。
var count;// 单个声明。
var count, amount, level;// 用单个 var 要害字声明的多个声明。
var count = 0, amount = 100;// 一条语句中的变量声明和初始化。
假如在 var 语句中没有初始化变量,变量自动取 JScript 值 undefined。尽管并不安全,但声明语句中忽略 var 要害字是合法的 JScript 语法。这时,JScript 解释器给予变量全局范围的可见度。当在过程级中声明一个变量时,它不能用于全局范围;这种情况下,变量声明必须用 var 要害字。
这里对“过程级声明变量的范围”显然没有说明白,也许是中英文翻译的问题。让我们来看一个实例:
function foo1(){
for(i=0;i<10;i++) ;
}
function foo2(){
alert(i);
}
foo1();
foo2(); 猜猜这样会有什么输出?还是错误?
事实是弹出一个对话框:10。但是假如先调用foo2()或把foo1()改成这样:
function foo1(){
var i;
for(i=0;i<10;i++) ;
}
却是什么都没有出现,而是一个脚本错误的提示:“i is undefined”。
所以我们可以看出,假如在函数中隐式声明了某个变量,那该变量将成为全局变量!像原foo1()函数中的变量i,循环后的值10将被保留,在foo2中就显示出来了。但是,假如在foo1()中用var显示声明了i,那它就是函数级的局部变量,在调用foo2()时自然无法找到i了。
看来在写JScript时虽然系统答应隐式变量声明使用,但我们还是应该进行显式的变量声明,尤其是对习惯的循环变量等,以保证它的使用范围。