你必須知道的Javascript知識點之'深入理解作用域鏈'的介紹_javascript技巧
May 16, 2016 pm 05:35 PM
javascript
作用域鏈
範例程式碼:
複製程式碼 程式碼如下:
var xxxVar1 = 1; outer = function(){
var xxxVar2 = 2;
var results = [];
對 for(var i = 0; 🎜> var inner = function(){
var xxxVar3 = 3;
}
results .push(inner);
}
return results;
}
var xxxVar1 = 100;
var xxxVar2 = 200;
var xxxVar3 = 300ar2 = 200;
var xxxVar3 = 300h; results[1]();
results[2]();
執行結果
發生了什麼事情很多人都可能知道上例的執行結果,但是不是所有人都明白為什麼會是這樣的結果,包括我自己。名詞解釋活動物件:一次函數呼叫開始的時候,javascript解釋器會收集函數體內的所有局部變數(以var形式宣告的變數),將這些局部變數儲存到一個稱為「活動物件」的物件裡,所有變數都初始為undefined。
複製程式碼
程式碼如下:var fun = function(){ alert(name); var name = '段光偉';
}執行這個函數時候時(fun()),函數體還沒執行到,目前的活動對象為[{ name: undefined }],因此fun()執行的結果為:
作用域鏈:當函數呼叫時,javascript引擎會維護一個這次呼叫的作用域鏈,這個作用域鏈條是函數的[scope]指向的作用域鏈加上函數呼叫時的活動對象,形式如[ 活動物件, 函數定義時的作用域鏈條]。

複製程式碼
程式碼如下:var a = 1;
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:[ {}, {
//步驟5:[ {}, {
, { function }, { function a: 1, outer: function } ]
return a b;
}
//步驟4:[ { b: 2, inner: function } out a:[ ]
return inner();
}
//步驟2:[ { a: 1, outer: function } ]
outer();
作用域鏈規則1
javascript一般運行在一定的宿主中,每個宿主都會提供一個“全局對象”,或者叫“全局活動對象”,這個全局對像是所有作用域鏈的根節點。規則2
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn

熱門文章
R.E.P.O.能量晶體解釋及其做什麼(黃色晶體)
2 週前
By 尊渡假赌尊渡假赌尊渡假赌
倉庫:如何復興隊友
3 週前
By 尊渡假赌尊渡假赌尊渡假赌
Hello Kitty Island冒險:如何獲得巨型種子
3 週前
By 尊渡假赌尊渡假赌尊渡假赌
擊敗分裂小說需要多長時間?
3 週前
By DDD
R.E.P.O.保存文件位置:在哪里以及如何保護它?
3 週前
By DDD

熱門文章
R.E.P.O.能量晶體解釋及其做什麼(黃色晶體)
2 週前
By 尊渡假赌尊渡假赌尊渡假赌
倉庫:如何復興隊友
3 週前
By 尊渡假赌尊渡假赌尊渡假赌
Hello Kitty Island冒險:如何獲得巨型種子
3 週前
By 尊渡假赌尊渡假赌尊渡假赌
擊敗分裂小說需要多長時間?
3 週前
By DDD
R.E.P.O.保存文件位置:在哪里以及如何保護它?
3 週前
By DDD

熱門文章標籤

記事本++7.3.1
好用且免費的程式碼編輯器

SublimeText3漢化版
中文版,非常好用

禪工作室 13.0.1
強大的PHP整合開發環境

Dreamweaver CS6
視覺化網頁開發工具

SublimeText3 Mac版
神級程式碼編輯軟體(SublimeText3)