欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

關(guān)于Javascript作用域鏈的八點總結(jié)

 更新時間:2013年12月06日 09:51:23   作者:  
其實吧,關(guān)于作用域鏈相關(guān)的文章我也看了不少,但是我一直也沒能做一個詳細的總結(jié),今天把我看到的一些東西,結(jié)合自己的想法,總結(jié)成以下8個點

1. JavaScript函數(shù)的作用域鏈分為定義時作用域鏈和運行時作用域鏈;

2.函數(shù)被定義的時候,它有一個屬性[[scope]]標明它的定義作用域鏈,定義時作用域鏈[[scope]]遵守這樣的規(guī)則:一個函數(shù)的定義時作用域鏈[[scope]]總是它所在的外部函數(shù)的執(zhí)行時作用域鏈;

3.全局函數(shù)的定義作用域鏈只包含window的屬性;

4.一個函數(shù)的執(zhí)行時作用域鏈總是在定義時作用域鏈的頭部壓入當前活動對象(它包含this,arguments,參數(shù),局部變量);

5.函數(shù)執(zhí)行時,變量尋址總是從作用域鏈的頂端朝下尋找;所以全局變量的尋址速度最慢;

6.內(nèi)部函數(shù)被執(zhí)行的時候,他仍然能夠訪問它完整的作用域鏈。這就是閉包能夠在運行時能夠訪問已經(jīng)結(jié)束的外部函數(shù)定義的變量的原因;

7.函數(shù)執(zhí)行遇到with語句時,會臨時在作用域鏈頂部壓入with指定的對象的所有屬性作為作用域鏈最頂端;

8.函數(shù)執(zhí)行遇到catch的時候,會臨時在作用域鏈頂部壓入catch指定的錯誤對象作為作用域鏈的最頂端;

下面給一個例子并繪制出作用域鏈,以加深理解:

有這么一段代碼:

復制代碼 代碼如下:

function assignEvents(){
    var id = "xdi9592";
    document.getElementById("save-btn").onclick = function(event){
        saveDocument(id);
    };
}

把此函數(shù)產(chǎn)生的匿名閉包稱為Closure,則繪制出下圖為assignEvent執(zhí)行時作用域鏈和Closure的定義時作用域鏈:

相關(guān)文章

最新評論