javascript
js中立即执行函数会预编译吗_JavaScript预编译过程
什么是預(yù)編譯?
當(dāng)js代碼執(zhí)行時(shí)有三個(gè)步驟:
1.語(yǔ)法分析,這個(gè)過(guò)程檢查出基本的語(yǔ)法錯(cuò)誤。
2,預(yù)編譯,為對(duì)象分配空間。
3,解釋執(zhí)行,解釋一行執(zhí)行一行,一旦出錯(cuò)立即停止執(zhí)行。
預(yù)編譯發(fā)生在代碼執(zhí)行的前一刻。
預(yù)編譯的具體過(guò)程:
預(yù)編的時(shí)候會(huì)生成AO (Activetion Object,執(zhí)行期上下文)和GO (Global Object,等于window)
【注1】先生成GO,生成后會(huì)逐行執(zhí)行代碼,遇到某個(gè)函數(shù)要執(zhí)行時(shí),在執(zhí)行前的前一刻會(huì)預(yù)編譯這個(gè)函數(shù),生成AO,
換言之,AO用于全局中的某個(gè)具體函數(shù),而GO用于整個(gè)全局,詳情請(qǐng)看下面例子:
運(yùn)行結(jié)果如下:
GO創(chuàng)建過(guò)程:
1.首先創(chuàng)建GO對(duì)象。
GO{}
2.在全局中尋找變量聲明作為GO的屬性,并將undefined賦給它。
GO{
b:undefined;
}
3.在全局中尋找函數(shù)聲明(【注2】注意不是變量賦值)作為GO屬性,并將函數(shù)體賦值于它。
GO{
b:function{...};(此時(shí)第二步中的b已被覆蓋成為function b);
}
然后開(kāi)始逐行執(zhí)行代碼,遇到第一個(gè)console.log(b);打印的是GO中的b;
AO創(chuàng)建過(guò)程:
第一次打印完b后,代碼執(zhí)行到 然后開(kāi)始創(chuàng)建AO,其創(chuàng)建過(guò)程和GO相似只是多了一步實(shí)參形參相統(tǒng)一而已。
1.創(chuàng)建AO對(duì)象。
AO{}
2.在相應(yīng)函數(shù)中尋找形參和變量聲明作為執(zhí)行期上下文的屬性,并將undefined賦給它們。
AO{
b:undefined;(這個(gè)b是變量b,此函數(shù)沒(méi)有形參)
}
3.實(shí)參形參相統(tǒng)一。
4.尋找函數(shù)聲明作為它的屬性,并將函數(shù)體賦給它。
AO{
b:function{...};(函數(shù)b將變量b覆蓋)
}
開(kāi)始執(zhí)行函數(shù)b,第二個(gè)console.log(b)結(jié)果為function(){},
執(zhí)行AO中b的值被賦成10,執(zhí)行第三個(gè)console.log(b)結(jié)果為10.
總結(jié)
以上是生活随笔為你收集整理的js中立即执行函数会预编译吗_JavaScript预编译过程的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問(wèn)題。
- 上一篇: C++学习之路 | PTA乙级—— 10
- 下一篇: 如何在js中使用ajax请求数据,在 J