DIV CSS 佈局教程網

 DIV+CSS佈局教程網 >> 網頁腳本 >> JavaScript入門知識 >> 關於JavaScript >> 你必須知道的Javascript知識點之深入理解作用域鏈的介紹
你必須知道的Javascript知識點之深入理解作用域鏈的介紹
編輯:關於JavaScript     
示例代碼:
復制代碼 代碼如下:
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並不支持。
  • XML學習教程| jQuery入門知識| AJAX入門| Dreamweaver教程| Fireworks入門知識| SEO技巧| SEO優化集錦|
    Copyright © DIV+CSS佈局教程網 All Rights Reserved