DIV CSS 佈局教程網

 DIV+CSS佈局教程網 >> 網頁腳本 >> JavaScript入門知識 >> 關於JavaScript >> JavaScript 函數的執行過程
JavaScript 函數的執行過程
編輯:關於JavaScript     

1. 每一個JavaScript函數都是Function對象的一個實例, 它有一個僅供JavaScript引擎存取的內部屬性[[Scope]]. 這個[[Scope]]存儲著一個作用域的集合, 這個集合就叫”作用域鏈”, 集合中存儲著”可變對象”VO或”活動對象”AO(AO比VO多this和arguments屬性).

2. 當函數被創建後, 其父級作用域的作用域鏈中的所有可變對象會被加入到它的[[scope]]中(如果父作用域是全局, 那麼當前函數的作用域鏈中就只會加入一個全局對象).

3. 當函數被執行時, 函數的執行環境會被推入一個環境棧中:

1.此時進入函數的變量初始化階段, 此階段會確定函數內部: this值, 函數的參數, 函數的聲明, 變量的聲明, 以及arguments. 根據這些值組成當前函數的活動對象AO, 之後會將AO對象保存到當前函數作用域鏈的首位.

注意: AO按如下順序填充:

1.函數參數(若有傳參, 會被賦值, 若未傳參, 初始化值為undefined) 優先級第二
2.函數聲明(若發生命名沖突, 會覆蓋) 優先級最高
3.變量聲明(初始化變量值為undefined, 若發生命名沖突, 會忽略) 優先級第三
2.然後就到了函數的執行階段, 此階段當前函數中使用到的所有變量和函數聲明都會從當前函數的[[Scope]]作用域鏈中查找, 根據作用域鏈中對象的位置首先會查找當前函數的AO對象, 如果沒有再查找上層對象, 最後找到全局對象, 如果都沒有則會報錯(變量未定義).

以上這篇JavaScript 函數的執行過程就是小編分享給大家的全部內容了,希望能給大家一個參考,也希望大家多多支持。

XML學習教程| jQuery入門知識| AJAX入門| Dreamweaver教程| Fireworks入門知識| SEO技巧| SEO優化集錦|
Copyright © DIV+CSS佈局教程網 All Rights Reserved