<delect id="sj01t"></delect>
  1. <em id="sj01t"><label id="sj01t"></label></em>
  2. <div id="sj01t"></div>
    1. <em id="sj01t"></em>

            <div id="sj01t"></div>

            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

            <delect id="sj01t"></delect>
            1. <em id="sj01t"><label id="sj01t"></label></em>
            2. <div id="sj01t"></div>
              1. <em id="sj01t"></em>

                      <div id="sj01t"></div>
                      黄色视频在线观看