黄视频网站在线免费观看-黄视频网站在线看-黄视频网站在线观看-黄视频网站免费看-黄视频网站免费观看-黄视频网站免费

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

手機站
千鋒教育

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

千鋒教育

掃一掃進入千鋒手機站

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

關(guān)注千鋒學(xué)習(xí)站小程序
隨時隨地免費學(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 (進入script作用域時,找到var)
            fn = function fn(){alert(2);}  (進入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 進行覆蓋)
            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)強師集結(jié),手把手帶你蛻變精英
請您保持通訊暢通,專屬學(xué)習(xí)老師24小時內(nèi)將與您1V1溝通
免費領(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
日韩专区一区| 国产视频一区二区在线观看| 国产麻豆精品免费密入口| 日韩中文字幕一区| 国产伦理精品| 精品国产香蕉伊思人在线又爽又黄| 一级毛片视频免费| 亚洲第一视频在线播放| 免费一级片在线观看| 好男人天堂网 久久精品国产这里是免费 国产精品成人一区二区 男人天堂网2021 男人的天堂在线观看 丁香六月综合激情 | 99久久网站| 成人a大片在线观看| 国产网站在线| 国产视频一区二区在线观看| 国产成人欧美一区二区三区的| 九九久久国产精品| 欧美日本二区| 国产精品免费久久| 国产91精品一区二区| 精品国产一区二区三区久久久蜜臀| 精品视频在线观看一区二区三区| 一本高清在线| 成人免费观看视频| 日本特黄特色aaa大片免费| 日韩欧美一及在线播放| 日韩av成人| 精品在线观看一区| 日韩在线观看免费| 国产91精品一区| 久久精品大片| 国产一区二区精品尤物| 国产伦精品一区二区三区无广告 | 国产国语对白一级毛片| 午夜精品国产自在现线拍| 黄视频网站在线看| 国产成人精品影视| 精品久久久久久中文字幕一区| 一级毛片视频免费| 国产一区精品| 国产一区二区精品| 美女免费毛片| 午夜精品国产自在现线拍| 国产亚洲免费观看| 亚洲www美色| 99色视频| 亚洲精品久久玖玖玖玖| 黄色免费三级| 高清一级片| 99久久视频| 成人免费高清视频| 久久精品欧美一区二区| 欧美激情在线精品video| 色综合久久天天综线观看| 日韩在线观看视频免费| 精品在线免费播放| 亚洲精品影院| 四虎影视库| 999久久66久6只有精品| a级黄色毛片免费播放视频| 成人av在线播放| 99色视频在线| 久久国产精品只做精品| 天天做日日干| 国产原创中文字幕| 韩国三级视频网站| 天天做日日爱夜夜爽| 日韩专区一区| 久久99爰这里有精品国产| 欧美国产日韩一区二区三区| 国产不卡在线看| 欧美一级视频免费| 日韩中文字幕一区| 日日日夜夜操| 亚洲精品中文一区不卡| 精品国产一区二区三区精东影业 | 日韩av成人| 久草免费在线观看| 免费国产在线观看| 欧美夜夜骑 青草视频在线观看完整版 久久精品99无色码中文字幕 欧美日韩一区二区在线观看视频 欧美中文字幕在线视频 www.99精品 香蕉视频久久 | 久久精品店| 色综合久久天天综合| 韩国三级视频网站| 二级特黄绝大片免费视频大片| 国产视频一区在线| 91麻豆爱豆果冻天美星空| 成人a级高清视频在线观看| 九九免费精品视频| 国产成人精品一区二区视频| 日本免费看视频| 国产麻豆精品免费视频| 你懂的国产精品| 亚洲天堂免费观看| 免费国产一级特黄aa大片在线| 欧美激情一区二区三区在线播放 | 日日爽天天| 夜夜操网| 欧美夜夜骑 青草视频在线观看完整版 久久精品99无色码中文字幕 欧美日韩一区二区在线观看视频 欧美中文字幕在线视频 www.99精品 香蕉视频久久 | 日本伦理片网站| 日本伦理片网站| 成人免费观看视频| 欧美a级大片| 亚洲第一色在线| 亚欧成人乱码一区二区| 麻豆系列 在线视频| 免费一级片在线| 四虎久久精品国产| 欧美国产日韩精品| 国产成人女人在线视频观看| 韩国毛片免费大片| 国产综合91天堂亚洲国产| 一本高清在线| 国产一级生活片| 精品视频免费在线| 国产91精品一区二区| 国产麻豆精品免费密入口| 一级毛片视频播放| 成人影视在线观看| 99久久精品国产高清一区二区| 色综合久久久久综合体桃花网| 亚洲天堂免费| 中文字幕一区二区三区精彩视频| 91麻豆高清国产在线播放| 美女免费毛片| 国产成人欧美一区二区三区的| 韩国三级视频网站| 美女免费精品高清毛片在线视| 日韩在线观看视频黄| 久久久久久久免费视频| 国产成人精品综合在线| 国产a毛片| 日韩一级黄色大片| 欧美另类videosbestsex视频| 日日日夜夜操| 国产成+人+综合+亚洲不卡| 中文字幕97| 在线观看成人网 | 麻豆系列 在线视频| 国产网站免费| 国产一级生活片| 国产综合91天堂亚洲国产| 国产网站在线| 九九九网站| 91麻豆tv| 亚洲第一色在线| 久久久久久久男人的天堂| 九九九国产| 97视频免费在线观看| 亚欧乱色一区二区三区| 久久成人综合网| 日本伦理网站| 亚洲精品影院| 精品视频一区二区三区| a级毛片免费观看网站| 亚洲wwwwww| 成人高清视频在线观看| 国产网站在线| 久久精品大片| 精品久久久久久综合网| 日韩中文字幕在线播放| 国产精品免费久久| 免费毛片播放| 夜夜操网| 久久99这里只有精品国产| 欧美爱爱网| 久久久久久久男人的天堂| 黄视频网站免费| 国产麻豆精品免费密入口| 日本免费看视频| 亚欧成人乱码一区二区| 国产原创中文字幕| 日韩在线观看视频网站| 精品久久久久久免费影院| 日韩在线观看免费| 免费国产在线视频| 成人免费高清视频| 欧美激情一区二区三区在线 | 国产视频在线免费观看| 91麻豆精品国产自产在线观看一区| 韩国三级视频网站| 国产91丝袜高跟系列| 亚洲wwwwww| 亚欧乱色一区二区三区| 国产不卡高清| 999精品影视在线观看| 一级毛片视频播放| 国产伦精品一区二区三区无广告| 四虎久久精品国产| 成人a大片在线观看| 久久久久久久网| 精品在线观看一区| 国产成人欧美一区二区三区的| 精品国产亚一区二区三区| 黄视频网站在线免费观看| 国产成人精品综合在线| 美女免费毛片| 二级片在线观看| 精品在线观看国产| 欧美a级片免费看| 日本伦理网站| 青青久热|