区别: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变量已经被声明,但不可访问。这段时间被成为临时死区。
【