JavaScript函數的執行過程

時間:2024-09-20 17:53:13 JavaScript 我要投稿
  • 相關推薦

JavaScript函數的執行過程

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

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

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

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

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

  1.函數參數(若有傳參, 會被賦值, 若未傳參, 初始化值為undefined) 優先級第二

  2.函數聲明(若發生命名沖突, 會覆蓋) 優先級最高

  3.變量聲明(初始化變量值為undefined, 若發生命名沖突, 會忽略) 優先級第三

  2.然后就到了函數的執行階段, 此階段當前函數中使用到的所有變量和函數聲明都會從當前函數的[[Scope]]作用域鏈中查找, 根據作用域鏈中對象的位置首先會查找當前函數的AO對象, 如果沒有再查找上層對象, 最后找到全局對象, 如果都沒有則會報錯(變量未定義).

【JavaScript函數的執行過程】相關文章:

淺析jQuery 遍歷函數javascript08-06

Javascript函數的定義和用法分析08-15

在Java中執行JavaScript代碼07-14

JavaScript中push(),join() 函數實例詳解09-05

最常用的20個javascript方法函數09-10

JavaScript日期時間格式化函數08-29

JavaScript中常見的字符串操作函數及用法07-24

php外部執行命令函數10-27

有關javascript實現的多個層切換效果通用函數示例10-07

JavaScript基于正則表達式數字判斷函數06-14

亚洲制服丝袜二区欧美精品,亚洲精品无码视频乱码,日韩av无码一区二区,国产人妖视频一区二区
亚洲欧美日韩一区在线观看 | 日本在线精品视频观看 | 日本三级欧美三级人妇视频 | 在线观看欧美gv视频网站 | 亚洲日韩中文字幕在线6页 日韩精品一区二区三区在线观看视频 | 亚洲国产精品综合久久20 |