淺談JavaScript的全域變數與局部變數_javascript技巧

來源:互聯網
上載者:User

一、JavaScript scope 的劃分標準是function函數塊,不是以 if、while、for來劃分的

<script>function f1(){   alert("before for scope:"+i);     //i未賦值(並不是沒有聲明!使用未聲明變數或函數會導致致命錯誤從而中斷指令碼執行) //此時i值為undefined   for(var i=0; i<3;i++){       alert("in for scope:"+i);} //i的值是0,1,2     alert(“after for scope:”+1);  //i的值是3,此時已經在for scope之外,但i的值仍然保留為3    while(true){       var j=1;       break;}    alert(j);  //j的值是1,此時已經在while scope之外,但j的值仍然保留為1    if(true){      var k=1;    }    alert(k);  //k的值為1,此時已經在if scope之外,但k的值仍保留為1}f1();//此時在函數塊外調用函數,再次輸出存在於f1這個function scope裡的i j k變數alert(i);//error!!!原因是這裡的i未聲明(不是未賦值,區別f1的第一行輸出),指令碼錯誤,程式結束!alert(j);    //未執行alert(k);//未執行</script>

二、JavaScript在執行之前會對整個指令檔進行先行編譯(對指令檔的聲明部分做分析,包括局部變數部分),從而確定實變數的範圍。舉個例子在下邊:

<script>   var x=1;   function f2(){    alert(x);   //x的值為undefined!這個x並不是全域變數,因為在function scope已經又聲明了一個重名的局部變數,所以全域變數的參數a被覆蓋了。    說明了JavaScript在執行前會進行先行編譯,函數體內的x就被指向局部變數,而不是全域變數。此時x只有聲明,沒有賦值,所以為undefined    x=3;    alert(x);   //x值為3.但還是局部變數    var x;   //局部變數x在這裡聲明    alert(x);   //值為3   }   f2();   alert(x);   //x值為1,並不是在function scope內,x的值為全域變數的值。</script>

三、當全域變數跟局部變數重名時,局部變數的scope會覆蓋掉全域變數的scope,當離開局部變數的scope後,又重回到全域變數的scope,而當全域變數遇上局部變數時,

怎樣使用全域變數呢?用window.globalVariableName。

<script>   var a=1;    function f3(){       alert(window.a);  //a位1,這裡的a是全域變數       var a=2;        alert(a);      }    f3();    alert(a);</script>

以上這篇淺談JavaScript的全域變數與局部變數就是小編分享給大家的全部內容了,希望能給大家一個參考,也希望大家多多支援雲棲社區。

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.