久久福利_99r_国产日韩在线视频_直接看av的网站_中文欧美日韩_久久一

您的位置:首頁技術(shù)文章
文章詳情頁

一起來了解一下JavaScript的預(yù)編譯(小結(jié))

瀏覽:106日期:2023-10-03 17:38:00
JS運行三部曲

js運行代碼共分三步

語法分析 預(yù)編譯 解釋執(zhí)行

JavaScript代碼在運行時,首先會進(jìn)行語法分析,通篇檢查代碼是否存在低級錯誤,然后進(jìn)行預(yù)編譯,整理內(nèi)部的一個邏輯,最后再開始一行一行的執(zhí)行代碼

語法分析

代碼在執(zhí)行之前,系統(tǒng)會通篇掃描一遍,檢查代碼有沒有低級的語法錯誤,比如少寫個大括號。

預(yù)編譯預(yù)編譯前奏

預(yù)編譯發(fā)生在函數(shù)執(zhí)行的前一刻。變量未經(jīng)聲明就賦值,此變量為全局對象所有

a = 3

var b = c = 4

一切聲明的全局變量,全是window的屬性

var a = 1 ===> window.a = 1

預(yù)編譯四部曲 創(chuàng)建AO(Activation Object)對象(里面存儲的是函數(shù)內(nèi)部的局部變量) 找形參和變量聲明,將變量和形參名做為AO屬性名,值為undefined 將實參和形參統(tǒng)一 在函數(shù)體里面找函數(shù)聲明,值賦予函數(shù)體

用一個例子來說明一下,也可以自己先給出一個答案,再繼續(xù)往下看

function fn(a) { console.log(a); var a = 123; console.log(a); function a() {} console.log(a); var b = function() {}; console.log(b); function d() {} console.log(d)}fn(1);

第一步,創(chuàng)建AO(Activation Object)對象 {}第二步,找形參和變量聲明,將變量和形參名做為AO屬性名,值為undefined

{ a: undefined, b: undefined,}

第三步,將實參和形參統(tǒng)一

{ a: 1, b: undefined,}

第四步,找函數(shù)聲明,值賦予函數(shù)體

{ a: function a() {}, b: undefined, d: function d() {}}

所以在函數(shù)fn執(zhí)行的前一刻,a、b、d的值如上所示

所以fn(1)執(zhí)行的結(jié)果為

// ƒ a() {}// 123// 123// ƒ () {}// ƒ d() {}

在全局作用域里,預(yù)編譯過程有些許不同

創(chuàng)建GO(Global Object)對象(里面存儲的是函數(shù)內(nèi)部的全局變量)GO === window 找形參和變量聲明,將變量和形參名做為GO屬性名,值為undefined 在函數(shù)體里面找函數(shù)聲明,值賦予函數(shù)體解釋執(zhí)行

一行一行的執(zhí)行代碼

實踐題

這里有幾個例題,有興趣的可以看一下

function test(a, b) { console.log(a); console.log(b); var b = 234; console.log(b); a = 123; console.log(a); function a() {} var a; b = 234; var b = function() {}; console.log(a); console.log(b);}test(1);

global = 100;function fn() { console.log(global); global = 200; console.log(global); var global = 300;}fn();var global;

function test() { console.log(b); if (a) { var b = 100; } c = 234; console.log(c);}var a;test();a = 10;console.log(c);總結(jié)

多數(shù)情況下,我們都是采用下面的這種方式來處理預(yù)編譯的一個過程

函數(shù)聲明,整體提升 變量聲明,聲明提升

若是遇見復(fù)雜的情況就只能采用最原始的方式來解決問題了

到此這篇關(guān)于一起來了解一下JavaScript的預(yù)編譯(小結(jié))的文章就介紹到這了,更多相關(guān)JavaScript 預(yù)編譯內(nèi)容請搜索好吧啦網(wǎng)以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持好吧啦網(wǎng)!

標(biāo)簽: JavaScript
相關(guān)文章:
主站蜘蛛池模板: 国产精品一区二区三区四区 | 看毛片网| 日韩精品在线视频 | 日韩一区二区在线免费观看 | 成人av免费在线观看 | 欧美日韩综合视频 | 日韩午夜激情视频 | 精品国产91亚洲一区二区三区www | 欧美国产精品久久久 | 日韩免费av一区二区 | 中文字幕在线播放第一页 | 日本在线观看视频网站 | 黑人精品xxx一区一二区 | 性做久久久久久 | 亚洲区在线 | 国产成人jvid在线播放 | 一级一级毛片 | 亚洲欧美中文日韩v在线观看 | 欧美一区二区在线看 | 国产日韩欧美精品 | 男女国产网站 | 婷婷激情五月 | 北条麻妃一区二区三区在线观看 | 五月婷婷丁香婷婷 | 日韩中文字幕a | 日韩在线成人 | 久久精品国产一区 | 久久亚洲国产 | www国产亚洲精品久久网站 | 久久伊人一区二区 | 亚洲精品乱码久久久久久9色 | 美女黄视频网站 | 男女羞羞视频免费看 | 久久极品 | 91精品国产色综合久久不卡98口 | 国产wwwcom | 久操草 | 欧美精品一区二区三区在线四季 | 日韩av一区在线 | 久久久久久久久99精品 | 在线一区观看 |