新聞中心
事實上或某種現(xiàn)象證明并不是這樣的,通過《JavaScript權(quán)威指南》及網(wǎng)上相關(guān)資料了解到,JavaScript有“預解析”行為。理解這一特性是很重要的,不然在實際開發(fā)中你可能會遇到很多無從解析的問題,甚至導致程序bug的存在。為了解析這一現(xiàn)象,也作為自己的一次學習總結(jié),本文逐步引導你來認識JavaScript“預解析”,如果我的見解有誤,還望指正。

創(chuàng)新互聯(lián)專注于企業(yè)成都全網(wǎng)營銷、網(wǎng)站重做改版、新?lián)峋W(wǎng)站定制設(shè)計、自適應品牌網(wǎng)站建設(shè)、HTML5、電子商務(wù)商城網(wǎng)站建設(shè)、集團公司官網(wǎng)建設(shè)、外貿(mào)網(wǎng)站建設(shè)、高端網(wǎng)站制作、響應式網(wǎng)頁設(shè)計等建站業(yè)務(wù),價格優(yōu)惠性價比高,為新?lián)岬雀鞔蟪鞘刑峁┚W(wǎng)站開發(fā)制作服務(wù)。
(1) 如果JavaScript僅是運行時自上往下逐句解析的,下面的代碼能正確運行是可以理解的,因為我們先定義函數(shù),然后才調(diào)用它。
- function showMsg { alert('This is message'); } showMsg; // This is message
(2) 我們也知道函數(shù)可以定義在調(diào)用代碼之后,如下代碼也是能正常工作的??雌饋碚{(diào)用showMsg的時候showMsg還是沒有定義的,但能正常工作,則表明JavaScript是“預解析”的。
- showMsg; // This is message function showMsg { alert('This is message'); }
(3) 上面是函數(shù)的例子,下面再來一個普通變量的例子。以下例子運行將會彈出undefined,表明***句的msg已經(jīng)是定義了,只是沒有初始化,它與var msg; alert(msg);是一樣的。如果你把下面第二句注釋掉,則會報“msg未定義”錯誤。這亦表明JavaScript是“預解析”的。
- alert(msg); //undefined var msg='This is message';
(4) 再來看一個例子,加深對JavaScript“預解析”印象。以下代碼你將看到兩次彈出的對話框都是顯示This is message 2,為什么會這樣呢?其實下面一前一后定義了兩個同名函數(shù),后面的showMsg覆蓋了前面定義的(在JavaScript中,同名變量一樣會存在覆蓋問題),等于***個showMsg報廢了。為什么第二次調(diào)用的showMsg不是調(diào)用它上面定義的那個message 1函數(shù)呢?這再次證明JavaScript有“預解析”行為。
- showMsg; // This is message 2 function showMsg { alert('This is message 1'); } showMsg; // This is message 2 function showMsg { alert('This is message 2'); }
(5) JavaScript“預解析”是把變量或函數(shù)預解析到它們能調(diào)用的環(huán)境(變量運行時環(huán)境)中。如下代碼看起來alert(msg)之前有看到msg的定義,但是程序運行還是報“msg未定義”錯誤,這是因為函數(shù)里定義的變量是函數(shù)的私有變量,外面不能直接調(diào)用,這表明JavaScript“預解析”并不是把所有定義的變量統(tǒng)一解析到一個全局對象中,比如window。
- function showMsg { var msg='This is message'; } alert(msg); // msg未定義
(6) JavaScript“預解析”是分段進行的,準確說是分
以上就是JavaScript 預解析的原理及實現(xiàn),希望對你有幫助。
分享標題:JavaScript預解析的原理及實現(xiàn)
網(wǎng)站地址:http://fisionsoft.com.cn/article/djecpog.html


咨詢
建站咨詢
