溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點(diǎn)擊 登錄注冊 即表示同意《億速云用戶服務(wù)條款》

javascript中預(yù)編譯指的是什么意思

發(fā)布時間:2022-03-10 12:01:34 來源:億速云 閱讀:158 作者:小新 欄目:web開發(fā)

這篇文章將為大家詳細(xì)講解有關(guān)javascript中預(yù)編譯指的是什么意思,小編覺得挺實用的,因此分享給大家做個參考,希望大家閱讀完這篇文章后可以有所收獲。

在JavaScript中,預(yù)編譯就是代碼執(zhí)行前進(jìn)行的一項操作,會把變量聲明提前,函數(shù)聲明也提前,把這些按照一定的規(guī)則,放在創(chuàng)建的對象里面去的一個過程。

本教程操作環(huán)境:windows10系統(tǒng)、javascript1.8.5版、Dell G3電腦。

javascript中什么是預(yù)編譯

js運(yùn)行三部曲

1.語法分析 : js引擎在解析js代碼之前,會先通篇掃描一下,找出低級的語法錯誤,比如寫錯大括號之類的。

2.預(yù)編譯 任何的語法和語句全部會被轉(zhuǎn)換成對象,GO(Global Object),AO(Active Object)把代碼按照 一定的規(guī)則,放到GO和AO中

3.解釋執(zhí)行 編譯一行執(zhí)行一行,當(dāng)語法分析沒有問題,并且已經(jīng)完成預(yù)編譯階段之后,就開始解釋執(zhí)行代碼

什么的預(yù)編譯?

預(yù)編譯就是在JavaScript代碼前進(jìn)行的一項操作會把變量聲明提前,函數(shù)聲明也提前,把這些代碼按照一定的規(guī)則,放在創(chuàng)建的對象里面去。

預(yù)編譯的過程:

GO window預(yù)編譯

1,在執(zhí)行script標(biāo)簽的一瞬間創(chuàng)建一個GO對象

2,尋找變量聲明,變量名作為GO對象的屬性名,值為undefined。

3,尋找函數(shù)聲明,函數(shù)名作為GO對象的屬性名,值為函數(shù)體,如果函數(shù)名和變量名一樣,直接覆蓋

AO 函數(shù)預(yù)編譯

1,在函數(shù)執(zhí)行的一瞬間創(chuàng)建一個AO對象

2,尋找實參和形參,將形參作為AO對象的屬性名添加到對象中,值為實參,值得注意的是,函數(shù)聲明不叫變量。如果沒有實參值就是undefined。

3,尋找變量聲明,變量名作為AO對象的屬性名,值為undefined。如果變量名和形參名一樣不用管。

4 ,尋找函數(shù)聲明,函數(shù)名作為AO對象的屬性名,值為函數(shù)體,如果函數(shù)名和變量名一樣,直接覆蓋

下面我們來寫一段代碼來簡單介紹一哈函數(shù)預(yù)編譯的過程

function fun(a,b){
    console.log(a);
    var a = 10;
    console.log(a);
    function a(){}
    console.log(a)
    a = 1;
    var b;
    console.log(b);
    var b = function(){}
    console.log(b);
}
fun(1,2);

1首先在執(zhí)行fun之前會創(chuàng)建一個AO對象。

funAO{
}

2,尋找實參和形參,將形參作為AO對象的屬性名添加到對象中,值為實參,值得注意的是,函數(shù)聲明不叫變量。如果沒有實參值就是undefined。

funAO{
    a : 1,
    b : 2
}

3,尋找變量聲明,變量名作為AO對象的屬性名,值為undefined。如果變量名和形參名一樣不用管

funAO{
    a : 1,
    b : 2
}

4 ,尋找函數(shù)聲明,函數(shù)名作為AO對象的屬性名,值為函數(shù)體,如果函數(shù)名和變量名一樣,直接覆蓋

funAO{
    a : function a(){},
    b : 2
}

解釋執(zhí)行

function fun(a,b){
    console.log(a);  //往上面的AO對象里面尋找,a的值是function a(){}。 這里就輸出function a(){}
    var a = 10;
    console.log(a);//上面一行代碼把a(bǔ)賦值10 ,所以這里輸出10
    function a(){}
    console.log(a)//這里也是10,因為上面函數(shù)已經(jīng)提前了
    a = 1;
    var b;
    console.log(b);//往上面的AO對象里面尋找,b的值是2。 這里就輸出2
    var b = function(){}//這里的函數(shù)為啥不能提前,因為這里的是一個函數(shù)表達(dá)式,這個函數(shù)沒有函數(shù)名所以不能提前。
    console.log(b);//這里把b賦值function(){},所以這里輸出function(){}
}
fun(1,2);

還有一種可能

function add(){
//這里的話碰到if判斷,for....除了function作用域之外的咱們都得正常分析,
//所以這里的值為undefined其實就是var a提前了賦值undefined
    console.log(a);//這里的輸出結(jié)果為?undefined
    if(a){
        var a = 10;
    }
    //這里是把a(bǔ)的值傳入判斷里面undefined返回的是false所以進(jìn)不去,值就不會改變這里還是undefined
    console.log(a);//undefined
}
add();

這上面就是預(yù)編譯的執(zhí)行過程!

關(guān)于“javascript中預(yù)編譯指的是什么意思”這篇文章就分享到這里了,希望以上內(nèi)容可以對大家有一定的幫助,使各位可以學(xué)到更多知識,如果覺得文章不錯,請把它分享出去讓更多的人看到。

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報,并提供相關(guān)證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI