亚洲 国产精品 日韩-亚洲 激情-亚洲 欧美 91-亚洲 欧美 成人日韩-青青青草视频在线观看-青青青草影院

千鋒教育-做有情懷、有良心、有品質(zhì)的職業(yè)教育機(jī)構(gòu)

手機(jī)站
千鋒教育

千鋒學(xué)習(xí)站 | 隨時隨地免費(fèi)學(xué)

千鋒教育

掃一掃進(jìn)入千鋒手機(jī)站

領(lǐng)取全套視頻
千鋒教育

關(guān)注千鋒學(xué)習(xí)站小程序
隨時隨地免費(fèi)學(xué)習(xí)課程

當(dāng)前位置:首頁  >  技術(shù)干貨  > 深度解析Javascript中的變量提升

深度解析Javascript中的變量提升

來源:千鋒教育
發(fā)布人:wjy
時間: 2022-06-02 14:12:00 1654150320

> 大家好,我是前端老陳醋,有關(guān)js中的變量提升,很多小伙伴可能都會有疑問,尤其是面試的過程中有大量有關(guān)于變量提升相關(guān)的題,那么瀏覽器在解析js的過程中,js中的變量究竟是怎么提升的呢?想要徹底解決這些問題,就要理解瀏覽器是怎么解析js代碼的,那么我們今天就來深度解析一下這個問題哈。

深度解析Javascript中的變量提升

## 首先在JS中涉及兩種作用域的問題,那么什么是作用域呢?

> 作用域是代碼中所使用名字的作用范圍,分為Script全局作用域和函數(shù)局部作用域。 當(dāng)瀏覽器在解析網(wǎng)頁內(nèi)容時,會分別啟動不同的解析器來解釋代碼的含義,如解析標(biāo)簽(超文本)的解析器、解析CSS樣式的解析器,解析javascript腳本的解析器。且解析過程為同步(按順序)解析。所以當(dāng)瀏覽器解析到script標(biāo)簽時,會停止對html和css的解析,同時啟動javascript的解析器。而在解析javascript的過程中我們主要關(guān)注解析器中的兩個步驟:

1. 預(yù)解析,即在當(dāng)前作用范圍中去尋找var、function、形參這三個內(nèi)容。

- 如果找到var關(guān)鍵字、則提取var后面的名字放到當(dāng)前作用域中,且默認(rèn)給這個變量初始化一個值為undefined。
- 如果找到function關(guān)鍵字,則提取函數(shù)名放到當(dāng)前作用域中,且將整個函數(shù)塊賦值給函數(shù)名。
- 如果找到形參,則將形參名放到當(dāng)前作用域中,且默認(rèn)初始化為undefined。這個過程也稱為變量提升。

\2. 逐行解讀代碼(即從上到下依次執(zhí)行每一條語句)且分為兩個步驟:

- 執(zhí)行表達(dá)式
- 函數(shù)調(diào)用。

```js
/*
        一、預(yù)解析(尋找var function 形參)
            i = undefined (進(jìn)入script作用域時,找到var)
            fn = function fn(){alert(2);}  (進(jìn)入script作用域時,找到function)
        二、逐行解讀代碼(函數(shù)聲明,直接跳過)
            1. 執(zhí)行表達(dá)式
            2. 函數(shù)調(diào)用
    */
    alert(i); //1. 當(dāng)執(zhí)行第一個表達(dá)式時,輸出i的值為undefined
    //第一個找到的是var,所以將i放到預(yù)解析中,初始化為undefined
    var i = 1; //2. 當(dāng)執(zhí)行第二個表達(dá)式i = 1時,會在預(yù)解析中先找到變量i,將值修改為1
    alert(i);//3. 當(dāng)執(zhí)行輸出表達(dá)式時,在預(yù)解析中i的值 1 輸出
    function fn(){ //4. 函數(shù)聲明,不執(zhí)行,直接跳過
        alert(2);
    }
    alert(i); //5. 當(dāng)執(zhí)行輸出表達(dá)式時,在預(yù)解析中i的值 1輸出
```

> 當(dāng)變量名與函數(shù)名相同時:

```js
/*
        一、預(yù)解析(尋找var function 形參)
            a = undefined  (在作用域中第一次找到var a) (在找到同名的函數(shù)a時,當(dāng)前變量a被丟棄)
            a = function a(){alert(2);}   (在作用域中第二次找到 function a,所以在作用域同時出現(xiàn)一個變量a和一個函數(shù)a,此時,將變量a丟棄,保留函數(shù)a) (在找到下一個function a時,此時的函數(shù) a 被覆蓋)
            a = function a(){alert(4);}   (在作用域中第三次找到function a時,與前面是相同的函數(shù) a,會將前面的函數(shù)a 進(jìn)行覆蓋)
            a = 1   (當(dāng)執(zhí)行到a = 1時,上面的a = function a(){alert(4);} 將被覆蓋成 1)
        二、逐行解讀代碼(函數(shù)聲明,直接跳過)
            1. 執(zhí)行表達(dá)式
            2. 函數(shù)調(diào)用
    */
    alert(a);  // 1. 在執(zhí)行該表達(dá)式時,預(yù)解析中只有 a = function a(){alert(4);} 所以此時的結(jié)果為   function a(){alert(4);}
    var a = 1;  // 第一次找到的 var a
    alert(a); //2. 在執(zhí)行該表達(dá)式時,預(yù)解析中的 a 值為 1 ,所以結(jié)果為  1
    function a(){ //第二次找到的 a
        alert(2);
    }
    function a(){  //第三次找到的  a
        alert(4);
    }
    alert(a);  // 3. 在執(zhí)行該表達(dá)式時,預(yù)解析中的 a 值為 1 ,所以結(jié)果為  1
```

> 當(dāng)有多個script標(biāo)簽時: - 多個script標(biāo)簽時,從上到下依次解析script作用域,所以建議將所有聲明的語句放到第一個script中。

```html
<script>
        /*
            一、預(yù)解析(尋找var function 形參)
                fn = function(){alert(2);} (在解析第一個script時,只找到一個funciton fn);

                a = 1  (在解析第二個script作用域時,找到 var a)
            二、逐行解讀代碼(函數(shù)聲明,直接跳過)
                1. 執(zhí)行表達(dá)式
                2. 函數(shù)調(diào)用
        */
        alert(a); //報錯,在執(zhí)行該表達(dá)式時,因為在預(yù)解析中沒有a變量,所以此時會報錯。
        function fn(){
            alert(2);
        }
    </script>
    <script>
        var a = 1;
        fn(); //2   在調(diào)用該函數(shù)時,在預(yù)解析中已經(jīng)存在function fn,所以輸出函數(shù)中的表達(dá)式 值為2
    </script>
```

更多關(guān)于“web前端培訓(xùn)”的問題,歡迎咨詢千鋒教育在線名師。千鋒已有十余年的培訓(xùn)經(jīng)驗,課程大綱更科學(xué)更專業(yè),有針對零基礎(chǔ)的就業(yè)班,有針對想提升技術(shù)的提升班,高品質(zhì)課程助理你實現(xiàn)夢想。

tags:
聲明:本站稿件版權(quán)均屬千鋒教育所有,未經(jīng)許可不得擅自轉(zhuǎn)載。
10年以上業(yè)內(nèi)強(qiáng)師集結(jié),手把手帶你蛻變精英
請您保持通訊暢通,專屬學(xué)習(xí)老師24小時內(nèi)將與您1V1溝通
免費(fèi)領(lǐng)取
今日已有369人領(lǐng)取成功
劉同學(xué) 138****2860 剛剛成功領(lǐng)取
王同學(xué) 131****2015 剛剛成功領(lǐng)取
張同學(xué) 133****4652 剛剛成功領(lǐng)取
李同學(xué) 135****8607 剛剛成功領(lǐng)取
楊同學(xué) 132****5667 剛剛成功領(lǐng)取
岳同學(xué) 134****6652 剛剛成功領(lǐng)取
梁同學(xué) 157****2950 剛剛成功領(lǐng)取
劉同學(xué) 189****1015 剛剛成功領(lǐng)取
張同學(xué) 155****4678 剛剛成功領(lǐng)取
鄒同學(xué) 139****2907 剛剛成功領(lǐng)取
董同學(xué) 138****2867 剛剛成功領(lǐng)取
周同學(xué) 136****3602 剛剛成功領(lǐng)取
相關(guān)推薦HOT
抖音小店運(yùn)營做什么的

在當(dāng)前的電商市場中,抖音小店已經(jīng)逐漸成為一種新的電商模式,它集成了社交化、音視頻分享、直播銷售等多種功能,使得消費(fèi)者更加便捷地進(jìn)行商品...詳情>>

2023-10-08 16:36:41
抖音小店照片要求尺寸多大

在抖音平臺開設(shè)小店已經(jīng)成為了越來越多人的選擇,相信大家已經(jīng)在各大社交平臺上看到有不少小店的推廣。在抖音上,照片是展示產(chǎn)品的重要手段,因...詳情>>

2023-10-08 16:14:25
抖音招商團(tuán)長托管服務(wù)費(fèi)怎么退回來

抖音招商團(tuán)長托管服務(wù)是抖音為有意愿創(chuàng)作內(nèi)容并帶動其他創(chuàng)作者成為團(tuán)隊成員的用戶提供的一種服務(wù)。通過該服務(wù),招商團(tuán)長可以自主組建團(tuán)隊并得到...詳情>>

2023-10-08 16:08:53
抖音小店怎么做代銷

抖音已經(jīng)成為了一個非常受歡迎的短視頻應(yīng)用程序,在其中許多用戶都精心打造了自己的小店,用于銷售各種各樣的商品,獲取額外的收入。然而,要想...詳情>>

2023-10-08 15:28:41
怎樣開抖音小店帶貨賺錢

隨著直播帶貨的火熱,越來越多的人開始嘗試通過抖音小店來開展帶貨業(yè)務(wù)。抖音小店是抖音直播帶貨的配套,可以讓用戶在購買直播中產(chǎn)品時就實現(xiàn)購...詳情>>

2023-10-08 15:06:36
肉蒲团之极乐宝鉴| 欧美性猛交XXXX黑人猛交| 男人女人做爽爽18禁免费| 热の无码热の有码热の综合| 天天摸夜夜添夜夜无码| 亚洲国产精彩中文乱码AV| 中文人妻AV高清一区二区| 槽溜2021入口一二三四| 国产激情一区二区三区成人| 精品少妇无码一区二区三批| 欧美成人精品A∨在线观看| 三个媳妇一锅烩大团圆| 亚洲AV成人永久网站www在线| 在线观看片免费人成视频无码| 成 人 网 站 在线 看 免费| 国色天香精品一卡2卡3卡| 免费观看大片的APP视频| 少妇三级全黄在线播放| 亚洲熟妇无码中文高清| 办公室被绑奶头调教羞辱OL| 国产亚洲人成A在线V网站| 久久久综合亚洲色一区二区三区| 强壮公弄得我次次高潮小说| 性猛交富婆Ⅹ×××乱大交| 2019NV天堂香蕉在线观看| 国产成人综合在线视频| 久久综合给合久久狠狠狠88| 日韩人妻不卡一区二区三区| 亚洲欧美另类久久久精品| 扒开双腿疯狂进出爽爽爽视频 | 人人妻人人妻人人片色AV| 亚洲AV午夜精品一区二区三区 | 免费A级毛片在线播放不收费| 色噜噜噜狠狠色一色伊人蜜桃| 亚洲国产成人综合精品| 波多野结衣AⅤ无码一区| 精品国产乱码一区二区三区| 日本japanese人妻护士| 亚洲日韩精品无码专区网站| 成年女人粗暴毛片免费观看| 精品无码国产自产野外拍在线| 日本一品和二品区别| 亚洲中文字幕成人无码| 国产成人AⅤ片在线观看| 久久天天躁狠狠躁夜夜AV不卡| 首页 图区 国产 亚洲 欧美| 在线天堂中文最新版WWW| 国产精品视频一区二区三区无码| 男人用嘴添女人私密视频| 午夜美女裸体福利视频| PLAY在线视频| 久久久久黑人强伦姧人妻| 外国操逼全黄视频| FIREEXⅩ性欧美HD护士| 精品久久久无码中文字幕一丶 | 人人妻人人澡人人爽欧美一区双| 亚洲色偷偷偷网站色偷一区人人藻| 哒哒哒WWW在线影院| 毛茸茸的撤尿正面BBW| 亚洲 欧美 中文 日韩AⅤ| 宝贝乖女小芳小雪| 久久婷婷五月综合色D啪| 无遮挡边摸边吃奶边做视频免费| WWW无人区一码二码三码区别| 久久精品成人无码观看不卡| 天堂中文在线资源| VICTORYDAY刺激性另类| 久久天天躁狠狠躁夜夜不卡| 性一交一乱一伦一| 动漫人物桶动漫人物免费观看网站| 免费黄色电影在线观看| 亚洲精品国产自在久久| 国产精品精华液网站| 日本COSME大赏美白| 18禁H免费动漫无码网站| 久久不见久久见免费影院3| 午夜福利一区二区三区在线观看| 把女人弄爽特黄A大片片| 秘密列车在线全集免费观看| 亚洲精品偷拍自综合网| 国产乱码字幕精品高清AV| 色综合久久精品亚洲国产消防| AV无码久久久久久不卡网站 | 95W乳液78WYW永久区域| 久久精品国产99久久久小说| 亚洲AV成人综合网伊人| 国产成人精品日本亚洲第一区| 人与牲动ZZZXXXⅩ0000| 97国产精华最好的产品在线| 久久亚洲AⅤ精品网站| 亚洲国产精品人人爽夜夜爽| 国产女人喷潮视频免费| 双乳被一左一右吃着的小说| 草莓视频在线播放视频| 欧美又大粗又爽又黄大片视频 | 亚洲VA在线∨A天堂VA欧美V| 国产精品久久久久久久久久免费| 日本入室强伦姧在线观看| BBW厕所白嫩BBW| 女人18毛片A级毛片视频| 中文午夜乱理片无码AⅤ| 久久久久久一区国产精品| 亚洲乱码日产精品B| 黑人又大又粗又硬XXXXX免费| 无码成人一区二区| 国产传媒精品1区2区3区| 熟女作爱一区二区视频| 国产AV电影区二区三区曰曰骚网| 日本三级香港三级人妇99| 办公室撕开奶罩揉吮奶头H文| 欧美熟妇与小伙性欧美交| AV天堂东京热无码专区| 内射在线CHINESE| 性欧美人与ZOZOXXXX视频| 免费毛片45分钟| 99精产国品一二三产区区别电影| 内射极品少妇一区二区av| 99国内精品久久久久影院| 欧美激欧美啪啪片免费看| MM1313午夜视频在线观看| 人妻丰满熟妇AV无码区APP| 宝贝腿开大点我添添公口述视频| 人禽杂交18禁网站免费| 吃花核心舌头在里面旋转| 色婷婷五月综合亚洲小说| 夫妻之间的100种插秧法| 他用舌头让我高潮视频| 国产精品日韩专区第一页| 亚洲AV乱码一区二区三区在线观看| 果冻传媒一二三工厂免费观看| 亚洲国产成人AV人片久久| 久久久久久精品免费免费HD| 杂乱小说2第400部| 妞干网在线视频免费观看 | 人妻体内射精一区二区 | 97久久国产亚洲精品超碰热| 欧美熟妇精品一区二区蜜桃视频 | 无码专区狠狠躁天天躁| 国产在线精品二区| 亚洲精华液一二三产区| 久久久久国产精品人妻AⅤ蜜臀| 中国人妻被两个老外三P| 欧美巨大黑人精品一二三| 波多野结衣人妻女教师4| 少妇人妻偷人精品无码视频| 国产日产欧产精品精品APP| 亚洲国产成人精品无码一区二区 | 激情内射人妻1区2区3区| 亚洲伊人久久大香线蕉AV| 免费无码AV一区二区波多野结衣| www.comAV在线观看| 日日狠狠久久偷偷色| 国产男男GaYGaY无套| 亚洲人ⅤSAⅤ国产精品| 内射人妻无码色AB麻豆| 成人动漫在线观看| 西西里大但人文艺术~任汾| 精品无人区无码乱码大片国产| 岳今晚让我玩个够肥水一体探岳体| 欧美精品成人A在线观看| 丰满顿熟妇好大BBBBBΒ| 午夜阳光精品一区二区三区| 久久精品国产亚洲AV无码偷窥| 94久久国产乱子伦精品免费| 色妞WWW精品视频| 狠狠噜天天噜日日噜视频麻豆| 伊人热热久久原色播放WWW| 欧美综合自拍亚洲图久青草| 国产成人精品无码片区| 亚洲精品无码久久| 欧美乱妇高清无乱码免费| 国产成人一区二区三区视频免费 | 亲孑伦视频一区二区三区| 国产精品VA尤物在线观看| 亚洲系列精品少妇系列50P| 女人18片毛片60分钟中国| 国产成人国产在线观看| 亚洲欧美中文日韩在线V日本| 欧美成人精品欧美一级乱黄 | 无码人妻毛片丰滿熟婦区毛片色欲| 久久精品国产99久久久香蕉 | 资源在线WWW天堂官网| 上司人妻互换HD无码| 精品无码久久久久国产APP| JIZZJIZZJIZZ日本老| 性色AV无码专区亚洲AV毛片子| 两男一女两根同进去舒服吗| 俄罗斯ZOOM与人性ZOOM| 亚洲日韩国产AV无码无码精品| 青青草原精品国产亚洲AV| 国产亚洲精品无码专区| 99国产欧美精品久久久蜜芽| 无码人妻AⅤ一区二区三区水密桃| 久久久无码精品亚洲日韩蜜桃| 大胸年轻继拇HD无码| 亚洲综合激情七月婷婷| 少妇高潮潮喷到猛进猛出小说| 久久久久久精品免费免费麻辣 | 无码熟熟妇丰满人妻PORN| 免费一对一真人视频APP|