1. 每一個JavaScript函數都是Function物件的一個實例, 它有一個僅供JavaScript引擎訪問的內部屬性[[Scope]]. 這個[[Scope]]存儲著一個作用域的集合, 這個集合就叫”作用域鏈”, 集合中存儲著”可變對象”VO或”活動對象”AO( AO比VO多this和arguments屬性).
2. 當函數被創建後, 其父級作用域的作用域鏈中的所有可變對象會被加入到它的[[scope]](如果父作用域是全域, 那麼當前函數的作用域鏈中就只會加入一個全域物件).
3. 當函數被執行時, 函數的執行環境會被推入一個環境堆疊中: p>
1.此時進入函數的變數初始化階段, 此階段會確定函數內部: this值, 函數的參數, 函數的宣告, 變數的宣告, 以及arguments. 根據這些值組成目前函數的活動物件AO,之後會將AO物件保存到目前函數作用域鏈的首位.
附註: AO會依照下列順序填入:
1.函數參數(若有傳參, 會被賦值, 若未傳參, 初始化值為undefined) 優先權第二
2.函數宣告(若發生命名衝突, 會覆蓋) 優先權最高
3.變數宣告(初始化變數值為undefined, 若發生命名衝突, 會忽略) 優先權第三
2.然後就到了函數的執行階段, 此階段當前函數中使用到的所有變數和函數聲明都會從當前函數的[[Scope]]作用域鏈中查找, 根據作用域鏈中對象的位置首先會查找當前函數的AO物件, 如果沒有再查找上層物件, 最後找到全域物件, 如果都沒有則會報錯(變數未定義).
以上這篇JavaScript 函數的執行過程就是小編分享給大家的全部內容了,希望能給大家一個參考,也希望大家多多支持腳本之家。