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

本教程操作環境:windows10系統、ECMAScript 6.0版、Dell G3電腦。
es6中let和var的區別是什么
let是在ES6中新引入的關鍵字,用來改進var帶來的各種問題。
let和var相比,大致有下面幾個方面的不同:
1、作用域
-
通過let定義的變量,作用域是在定義它的塊級代碼以及其中包括的子塊中,并且無法在全局作用域添加變量。
-
通過var定義的變量,作用域為包括它的函數作用域或者全局作用域。
2、重復聲明
-
通過let定義的變量,在同一個作用域內,不可以重復聲明。
-
通過var定義的變量,在同一個作用域內,重復聲明,在生成執行上下文的時候,會無視后面的聲明。
3、臨時死區引起的提升等問題
我們知道在代碼執行之前,會先掃描所有域內的var聲明的變量,將其先進行初始化為undefined,然后再執行代碼,也就是所謂的“提升”現象。
但對于let聲明的變量而言,則有所不同。在代碼執行之前的掃描,同樣也會對let變量進行“提升”,但并沒有將其置為undefined。let定義的變量雖然經歷了提升,但在沒有執行到初始化它的代碼前,該變量并沒有被初始化,如果此時訪問的話,會被置為ReferenceError錯誤。從代碼塊開始到執行到let變量初始化完畢這段時間,let變量已經被聲明,但不可訪問。這段時間被成為臨時死區。
【
站長資訊網