實(shí)例分析瀏覽器中“JavaScript解析器”的工作原理
瀏覽器在讀取HTML文件的時(shí)候,只有當(dāng)遇到<script>標(biāo)簽的時(shí)候,才會喚醒所謂的“JavaScript解析器”開始工作。
JavaScript解析器工作步驟:
1、“找一些東西”: var、 function、 參數(shù);(也被稱之為預(yù)解析)
備注:如果遇到重名分為以下兩種情況:
- 遇到變量和函數(shù)重名了,只留下函數(shù)
- 遇到函數(shù)重名了,根據(jù)代碼的上下文順序,留下最后一個(gè)
2、逐行解讀代碼。
備注:表達(dá)式可以修改預(yù)解析的值
JS解析器在執(zhí)行第一步預(yù)解析的時(shí)候,會從代碼的開始搜索直到結(jié)尾,只去查找var、function和參數(shù)等內(nèi)容。一般把第一步稱之為“JavaScript的預(yù)解析”。而且,當(dāng)找到這些內(nèi)容時(shí),所有的變量,在正式運(yùn)行代碼之前,都提前賦了一個(gè)值:未定義;所有的函數(shù),在正式運(yùn)行代碼之前,都是整個(gè)函數(shù)塊。
實(shí)例分析:
實(shí)例一:
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>Document</title> <script type="text/javascript"> alert(a); </script> </head> <body> </body> </html>
這段代碼運(yùn)行后,瀏覽器會報(bào)錯。
原因:由于,“JavaScript解析器”在解析JS代碼時(shí),未找到var、function、參數(shù)等其中的任何一個(gè),所以,當(dāng)逐行執(zhí)行代碼時(shí),因?yàn)樵凇皞}庫”中找不到a,不認(rèn)識a,就會報(bào)錯。
實(shí)例二:
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>Document</title> <script type="text/javascript"> alert(a); var a = 1; </script> </head> <body> </body> </html>
這段代碼運(yùn)行后,瀏覽器會彈出”undefined”。
原因:由于,“JavaScript解析器”在解析JS代碼時(shí),找到var關(guān)鍵字,然后得知有一個(gè)變量a,所以會給a默認(rèn)賦值一個(gè)undefined值,存入“倉庫”中,所以,當(dāng)逐行執(zhí)行代碼時(shí),找到變量a,因?yàn)榇藭r(shí)的a的值為undefined,所以彈出的值為undefined。
實(shí)例三:
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>Document</title> <script type="text/javascript"> var a = 1; alert(a); </script> </head> <body> </body> </html>
這段代碼運(yùn)行后,瀏覽器會彈出數(shù)字“1”。
原因:由于,“JavaScript解析器”在解析JS代碼時(shí),找到var關(guān)鍵字,然后得知有一個(gè)變量a,所以會給a默認(rèn)賦值一個(gè)undefined值,存入“倉庫”中,在逐行執(zhí)行代碼時(shí),先找到變量a,此時(shí)的a的值為undefined,當(dāng)執(zhí)行到var a= 1 這行代碼時(shí),a得到了一個(gè)新的賦值“1”所以彈出的值為數(shù)字“1”。
實(shí)例四:
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>Document</title>
<script type="text/javascript">
alert(a);
var a = 1;
alert(a);
function a () {
alert(2);
}
alert(a);
var a = 3;
alert(a);
function a () {
alert(4);
}
alert(a);
</script>
</head>
<body>
</body>
</html>
這段代碼運(yùn)行后,彈出值的順序依次為:function a () {alert(4);}、1、1、3、3
原因:由于,“JavaScript解析器”在逐行解析代碼時(shí),先找到var關(guān)鍵字,然后得知有一個(gè)變量a,所以會給a默認(rèn)賦值一個(gè)undefined值,存入“倉庫”中,然后,繼續(xù)向下解析代碼,當(dāng)找到function a () {alert(2);}時(shí),根據(jù)“函數(shù)和變量重名,保留函數(shù)”的規(guī)則,此時(shí)的a變?yōu)閒unction () {alert(2);},再繼續(xù)向下找,當(dāng)找到變量a的時(shí)候,不變,仍繼續(xù)向下找,當(dāng)找到函數(shù)function () {alert(4);}時(shí),根據(jù)“函數(shù)重名上下文”原則,替換為function () {alert(4);},最終a被賦值為function () {alert(4);},存到“倉庫”中,當(dāng)逐行執(zhí)行代碼時(shí),執(zhí)行到第一個(gè)alert(a)時(shí),將會彈出“function () {alert(4);}”,接著向下執(zhí)行,當(dāng)執(zhí)行到a=1時(shí),由于表達(dá)式可以改變預(yù)解析的值,所以此時(shí)的a變?yōu)?,執(zhí)行到第二個(gè)alert(a)時(shí),彈出值為1,當(dāng)執(zhí)行到function a () {alert(2);}時(shí),由于此時(shí)是一個(gè)函數(shù)聲明,并不會修改a的值,所以執(zhí)行到第三個(gè)alert(a)時(shí),彈出的仍為數(shù)字“1”,依次類推,此后將會陸續(xù)彈出“3”、“3”。
以上就是本文的全部內(nèi)容,希望本文的內(nèi)容對大家的學(xué)習(xí)或者工作能帶來一定的幫助,同時(shí)也希望多多支持腳本之家!
相關(guān)文章
11個(gè)Javascript小技巧幫你提升代碼質(zhì)量(小結(jié))
這篇文章主要介紹了11個(gè)Javascript小技巧幫你提升代碼質(zhì)量(小結(jié)),文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2020-12-12
靈活使用數(shù)組制作圖片切換js實(shí)現(xiàn)
這篇文章主要介紹了靈活使用數(shù)組制作圖片切換效果,js實(shí)現(xiàn)圖片切換特效,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2016-07-07
用于節(jié)點(diǎn)操作的API,顛覆原生操作HTML DOM節(jié)點(diǎn)的API
敏捷開發(fā)是一種以人為核心、迭代、循序漸進(jìn)的開發(fā)方法。在敏捷開發(fā)中,軟件項(xiàng)目的構(gòu)建被切分成多個(gè)子項(xiàng)目,各個(gè)子項(xiàng)目的成果都經(jīng)過測試,具備集成和可運(yùn)行的特征。2010-12-12

