JScript中的隐式变量声明和var变量声明
2009-10-20 09:47
162 查看
JScript中的隐式变量声明和var变量声明
以前一直没注重到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时虽然系统答应隐式变量声明使用,但我们还是应该进行显式的变量声明,尤其是对习惯的循环变量等,以保证它的使用范围。
相关文章推荐
- JScript中的隐式变量声明和var变量声明
- JScript中的隐式变量声明和var变量声明
- angularJS2 变量声明 var let const
- 在 JavaScript 核心语言中,全局对象的预定义属性都是不可枚举的,所有可以用 for/in 循环列出所有隐式或显式声明的全局变量
- for循环绑定事件时,var和let声明循环变量的区别
- JS中VAR的用处(局部变量要用var来声明,全局变量不加var)
- 变量不加 var 声明——掉进坑中,无法自拔!
- var与Javascript变量隐式声明
- js的链式作用域和var变量声明
- Node.js 中 变量声明 带var 和不带var 的情况
- JavaScript中变量声明有var和没var的区别示例介绍
- JS中的变量声明——var,let,const的区别
- JavaScript声明变量时为什么要加var关键字
- JavaScript的隐式声明和变量声明提升的总结
- 在函数内部定义的变量加与不加var的区别,匿名函数和有名函数内声明变量的区别
- 微信开发之js声明变量用"var"与不用"var"的区别
- JS中用var声明变量和不用的区别
- 声明变量,一定要用 var!
- js 变量声明 (var使用与不使用的区别)
- javascript函数内部用var声明临时变量需要注意的