首頁 >web前端 >js教程 >javascript預編譯做了啥

javascript預編譯做了啥

醉折花枝作酒筹
醉折花枝作酒筹原創
2021-07-22 11:36:292052瀏覽

javascript預編譯做了:1、語法分析,就是引擎檢查你的程式碼有沒有什麼低階的語法錯誤;2、預編譯,簡單理解就是在記憶體中開闢一些空間,存放一些變數與函數;3、解釋執行,顧名思義便是執行程式碼了。

javascript預編譯做了啥

本教學操作環境:windows7系統、javascript1.8.5版、Dell G3電腦。

JavaScript運行三部曲

  • 語法分析

  • #預先編譯

#解釋執行

  • 語法分析很簡單,就是引擎檢查你的程式碼有沒有什麼低階的語法錯誤;解釋執行顧名思義便是執行程式碼了;預編譯簡單理解就是在內存中開闢一些空間,存放一些變數與函數;

  • JS預編譯什麼時候發生
  • #預編譯到底什麼時候發生? 誤以為預編譯僅僅發生在script內程式碼區塊執行前這倒並沒有錯預編譯確確實實在script程式碼內執行前發生了但是它大部分會發生在函數執行前

  • 實例分析
  • #先來區分理解一下這2個概念:變數宣告var … 函數宣告function(){}

    <script>
    var a = 1;
    console.log(a);
    function test(a) {
      console.log(a);
      var a = 123;
      console.log(a);
      function a() {}
      console.log(a);
      var b = function() {}
      console.log(b);
      function d() {}
    }
    var c = function (){
    console.log("I at C function");
    }
    console.log(c);
    test(2);
    </script>
  • 分析過程如下:
  • 頁面產生便建立了GO全域物件(Global Object)(也就是window物件);

第一個腳本檔案載入;腳本載入完畢後,分析語法是否合法;

    開始預先編譯尋找變數聲明,作為GO屬性,值賦予undefined; 
  • 查找函數聲明,作為GO屬性,值賦予函數體;
  • 預先編譯
  • //抽象描述
        GO/window = {
            a: undefined,
            c: undefined,
            test: function(a) {
                console.log(a);
                var a = 123;
                console.log(a);
                function a() {}
                console.log(a);
                var b = function() {}
                console.log(b);
                function d() {}
            }
        }

    解釋執行程式碼(直到執行呼叫函數test(2)語句)

    //抽象描述
        GO/window = {
            a: 1,
            c: function (){
                console.log("I at C function");
            }
            test: function(a) {
                console.log(a);
                var a = 123;
                console.log(a);
                function a() {}
                console.log(a);
                var b = function() {}
                console.log(b);
                function d() {}
            }
        }
  • 執行函數test()之前,發生預編譯
  • 建立AO活動物件(Active Object);

尋找形參與變數聲明,值賦予undefined;

實參值賦給形參;

找出函數聲明,值賦予函數體;javascript預編譯做了啥

#預先編譯之前面1、2兩小步驟如下:

//抽象描述
    AO = {
        a:undefined,
        b:undefined,
    }

預編譯之第3步如下:

//抽象描述
        AO = {
            a:2,
            b:undefined,
        }

預編譯之第4步如下:
    //抽象描述
        AO = {
            a:function a() {},
            b:undefined
            d:function d() {}
        }
  • 執行test()函數時如下程序變更:

    //抽象描述
        AO = {
            a:function a() {},
            b:undefined
            d:function d() {}
        }
        --->
        AO = {
            a:123,
            b:undefined
            d:function d() {}
        }
        --->
        AO = {
            a:123,
            b:function() {}
            d:function d() {}
        }

    執行結果:
  • 注意:
  • #預編譯階段發生變數宣告和函數聲明,沒有初始化行為(賦值),匿名函數不參與預編譯; 只有在解釋執行階段才會進行變數初始化;

  • 預編譯(函數執行前)
  • #建立AO物件(Active Object)

    找出函數形參及函數內變數聲明,形參名及變數名稱作為AO物件的屬性,值為undefined
  • 實參形參相統一,實參值賦給形參
  • 查找函數聲明,函數名稱作為AO物件的屬性,值為函數引用

    預編譯(腳本程式碼區塊script執行前)
  • 尋找全域變數宣告(包含隱式全域變數聲明,省略var聲明),變數名為全域物件的屬性,值為undefined
    • 查找函數聲明,函數名稱作為全域物件的屬性,值為函數引用
    • #預編譯小結
    預編譯兩個小規則
    • 函數宣告整體提升-(具體點說,無論函數呼叫和宣告的位置是前是後,系統總是會把函數宣告移到呼叫前面)
    • 變數宣告提升-(具體點說,無論變數呼叫和宣告的位置是前是後,系統總是會把宣告移到呼叫前,注意僅只是聲明,所以值是undefined)
    #預編譯前奏
imply global 即任何變量,如果未經聲明就賦值,則此變數就位全域變數所有。 (全域是Window)

一切宣告的全域變量,全是window的屬性;var a = 12;等同於Window.a = 12;######## ##############函數預編譯發生在函數執行前一刻。 ############【推薦學習:###javascript進階教學###】###

以上是javascript預編譯做了啥的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn