久久久久久久视色,久久电影免费精品,中文亚洲欧美乱码在线观看,在线免费播放AV片

<center id="vfaef"><input id="vfaef"><table id="vfaef"></table></input></center>

    <p id="vfaef"><kbd id="vfaef"></kbd></p>

    
    
    <pre id="vfaef"><u id="vfaef"></u></pre>

      <thead id="vfaef"><input id="vfaef"></input></thead>

    1. 站長資訊網(wǎng)
      最全最豐富的資訊網(wǎng)站

      es6中l(wèi)et和var的區(qū)別是什么

      區(qū)別:1、let變量的作用域是在定義它的塊級(jí)代碼中,而var變量的作用域是在包括它的函數(shù)作用域中;2、let變量不能重復(fù)聲明,而var變量可以重復(fù)聲明;3、代碼執(zhí)行之前的掃描會(huì)將var變量初始化為undefined,而let變量沒有初始化。

      es6中l(wèi)et和var的區(qū)別是什么

      本教程操作環(huán)境:windows10系統(tǒng)、ECMAScript 6.0版、Dell G3電腦。

      es6中l(wèi)et和var的區(qū)別是什么

      let是在ES6中新引入的關(guān)鍵字,用來改進(jìn)var帶來的各種問題。

      let和var相比,大致有下面幾個(gè)方面的不同:

      1、作用域

      • 通過let定義的變量,作用域是在定義它的塊級(jí)代碼以及其中包括的子塊中,并且無法在全局作用域添加變量。

      • 通過var定義的變量,作用域?yàn)榘ㄋ暮瘮?shù)作用域或者全局作用域。

      2、重復(fù)聲明

      • 通過let定義的變量,在同一個(gè)作用域內(nèi),不可以重復(fù)聲明。

      • 通過var定義的變量,在同一個(gè)作用域內(nèi),重復(fù)聲明,在生成執(zhí)行上下文的時(shí)候,會(huì)無視后面的聲明。

      3、臨時(shí)死區(qū)引起的提升等問題

      我們知道在代碼執(zhí)行之前,會(huì)先掃描所有域內(nèi)的var聲明的變量,將其先進(jìn)行初始化為undefined,然后再執(zhí)行代碼,也就是所謂的“提升”現(xiàn)象。

      但對于let聲明的變量而言,則有所不同。在代碼執(zhí)行之前的掃描,同樣也會(huì)對let變量進(jìn)行“提升”,但并沒有將其置為undefined。let定義的變量雖然經(jīng)歷了提升,但在沒有執(zhí)行到初始化它的代碼前,該變量并沒有被初始化,如果此時(shí)訪問的話,會(huì)被置為ReferenceError錯(cuò)誤。從代碼塊開始到執(zhí)行到let變量初始化完畢這段時(shí)間,let變量已經(jīng)被聲明,但不可訪問。這段時(shí)間被成為臨時(shí)死區(qū)。

      贊(0)
      分享到: 更多 (0)
      網(wǎng)站地圖   滬ICP備18035694號(hào)-2    滬公網(wǎng)安備31011702889846號(hào)