1. javascript無塊級作用域,變量在函數內部可見。

  1. function func_scope(){
  2.     var x=1;
  3.     if (true) {
  4.         var x=2;
  5.         if (true) {
  6.             var x=3;
  7.             alert(x);
  8.         }
  9.         alert(x);
  10.     }
  11.     alert(x);
  12. }
  13. func_scope();
這個地方具體是一個x變量,還是3個真不清楚?其實也沒人有毛病這樣定義變量

輸出:
3
3
3
2. 對象初始化可以對自身的屬性執行修改,可以修改全局變量的值。

  1. function foo(){
  2.     foo.abc = function(){alert('def')};
  3.     this.abc = function(){alert('xyz')};
  4.     abc = function(){alert('@@@@@')};
  5.     var abc = function(){alert('$$$$$$')};
  6. }
  7. foo.prototype.abc = function(){alert('456');}
  8. foo.abc = function(){alert('123');}
  9. var f = new foo();
  10. f.abc();
  11. foo.abc();
  12. abc();

輸出:
xyz
def
錯誤: abc is not defined (相應解釋在第3個例子中)
3. 函數內,只要變量名前面出現var則該變量為局部變量。

  1. var myVar"GLOBAL";
  2. function foo() {
  3.     // myVar已經在下面聲明,但是在此之前卻沒有定義
  4.     alert("myVar evaluates to '"+myVar+"'");
  5.     // 這個myVar其實是局部變量
  6.     myVar = "NEW_GLOBAL_VALUE";
  7.     alert("myVar evaluates to '"+myVar+"'");
  8.     // window.myVar指向全局的myVar
  9.     alert("myVar evaluates to '"+window.myVar+"'");
  10.     // 聲明一個局部變量myVar,去掉這個則輸出結果就完全不同
  11.     var myVar = "LOCAL";
  12.     alert("myVar evaluates to '"+myVar+"'");
  13. }
  14. foo();
  15. alert("myVar evaluates to '"+myVar+"'");

輸出:
myVar evaluates to ‘undefined’
myVar evaluates to ‘NEW_GLOBAL_VALUE’
myVar evaluates to ‘GLOBAL’
myVar evaluates to ‘LOCAL’
myVar evaluates to ‘GLOBAL’

對應第2個例子,foo中的abc(abc = function(){alert(’@@@@@’)};)為局部變量,全局變量中沒有定義過abc所以會報undefine的錯誤。


結論:
* 1.只要在函數內部聲明變量使用了var,不管是if(false){var aa}, 他都是局部變量;反之,是全局變量;
* 2.聲明所有的變量都應該加上var,防止產生歧義;
* 3.盡量避免引入全局變量。