3、JavaScript没有块级作用域。 这一点也是JavaScript相比其它语言较灵活的部分。 仔细观察下面的代码,你会发现变量i、j、k作用域是相同的,他们在整个rain函数体内都是全局的。 复制代码 代码如下: <script type="text/javascript" language="javascript"> function rainman(){ /** * rainman函数体内存在三个局部变量 i j k */ var i = 0; if( 1 ){ var j = 0; for( var k = 0 ; k < 3 ; k++ ){ alert( k ); //分别弹出 0 1 2 } alert( k ); //弹出3 } alert( j ); //弹出0 } </script>
4、函数中声明的变量在整个函数中都有定义。 首先观察这段代码。 复制代码 代码如下: <script type="text/javascript" language="javascript"> function rain(){ var x = 1; function man(){ x = 100; } man(); //调用man alert( x ); //这里会弹出 100 } rain(); //调用rain </script>
上面得代码说明了,变量x在整个rain函数体内都可以使用,并可以重新赋值。由于这条规则,会产生“匪夷所思”的结果,观察下面的代码。 这是由于在函数rain内局部变量x在整个函数体内都有定义( var x= 'rain-man',进行了声明),所以在整个rain函数体内隐藏了同名的全局变量x。这里之所以会弹出'undefined'是因为,第一个执行alert(x)时,局部变量x仍未被初始化。 复制代码 代码如下: <script type="text/javascript" language="javascript"> var x = 1; function rain(){ alert( x ); //弹出 'undefined',而不是1 var x = 'rain-man'; alert( x ); //弹出 'rain-man' } rain() </script>
所以上面的rain函数等同于下面的函数。 复制代码 代码如下: function rain(){ var x; alert( x ); x = 'rain-man'; alert( x ); }
5、未使用var关键字定义的变量都是全局变量。 复制代码 代码如下: <script type="text/javascript" language="javascript"> function rain(){ x = 100; //声明了全局变量x并进行赋值 } rain(); alert( x ); //会弹出100 </script>
这也是JavaScript新手常见的错误,无意之中留下的许多全局变量。 6、全局变量都是window对象的属性 复制代码 代码如下: <script type="text/javascript" language="javascript"> var x = 100 ; alert( window.x );//弹出100 alert(x); </script>