你必須知道的Javascript知識點之”深入理解範圍鏈”的介紹

來源:互聯網
上載者:User

範例程式碼: 複製代碼 代碼如下:var xxxVar1 = 1;
var outer = function(){
var xxxVar2 = 2;

var results = [];

for(var i = 0; i< 3; i++)
{
var inner = function(){
var xxxVar3 = 3;
return xxxVar3 + xxxVar2 +xxxVar1 + i;
}
results .push(inner);
}

return results;
}

var xxxVar1 = 100;
var xxxVar2 = 200;
var xxxVar3 = 300;
var results = outer();
results[0]();
results[1]();
results[2]();

執行結果

發生了什麼事情很多人都可能知道上例的執行結果,但是不是所有人都明白為什麼會是這樣的結果,包括我自己。名詞解釋使用中的物件:一次函數調用開始的時候,javascript解譯器會收集合函式體中的所有局部變數(以var形式聲明的變數),將這些局部變數儲存到一個稱為“使用中的物件”的對象裡,所有變數都初始為undefined。
程式碼範例複製代碼 代碼如下:var fun = function(){
alert(name);
var name = '段光偉';
}

當執行這個函數時候時(fun()),函數體還沒執行到,當前的使用中的物件為[{ name: undefined }],因此fun()執行的結果為:

  • 函數的[scope]屬性:每個函數在定義的時候(產生函數執行個體的時候)都會分配一個[scope]屬性,這個屬性指向的當前的“範圍鏈”。這個屬性開發人員是訪問不到的,只有javascript能訪問。
  • 範圍鏈:當函數調用時,javascript引擎會維護一個這次調用的範圍鏈,這個範圍鏈條是函數的[scope]指向的範圍鏈加上函數調用時的使用中的物件,形式如[ 使用中的物件, 函數定義時的範圍鏈條]。
    程式碼範例複製代碼 代碼如下:var a = 1;
    //步驟1:[ { a: 1, outer: undefined } ]

    var outer = function(){
    //步驟3:[ { b: undefined, inner: undefined } ,{ a: 1, outer: function } ]
    var b = 2;
    var inner = function(){
    //步驟5:[ {}, { b: 2, inner: function } ,{ a: 1, outer: function } ]
    return a + b;
    }

    //步驟4:[ { b: 2, inner: function } ,{ a: 1, outer: function } ]
    return inner();
    }

    //步驟2:[ { a: 1, outer: function } ]
    outer();

    範圍鏈規則規則1

    javascript一般運行在一定的宿主中,每個宿主都會提供一個“全域對象”,或者叫“全域使用中的物件”,這個全域對象是所有範圍鏈的根節點。

    規則2

    “取值操作”(如:alert(xxxVar))的規則是,沿著範圍鏈依次尋找名稱為“xxxVar”的變數,返回第一個找到的值,如果找不到就拋出異常(ReferenceError: xxxVar is not defined)。

    規則3

    “賦值操作”(如:xxxVar = '段光偉')的規則是,沿著範圍鏈依次尋找名稱為“xxxVar”的變數,覆蓋第一個找到的值,如果找不到就將“xxxVar”添加到全域對象中。

    備忘“閉包”這個概念就是通過“範圍鏈”實現的,而C#是通過編譯器實現的,.NET並不支援。

  • 相關文章

    聯繫我們

    該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在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.