您的位置:首页 > Web前端 > JavaScript

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时虽然系统答应隐式变量声明使用,但我们还是应该进行显式的变量声明,尤其是对习惯的循环变量等,以保证它的使用范围。
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: