1.块级作用域:
ES6新增的let和const具有块级作用域,解决了ES5当中的两个问题
(1)内层变量覆盖外层,导致全局污染问题
(2)用来计数像for(var i)会全局泄露
2.声明提升
var 存在声明提升,let和const只能在声明后使用 不然会报错
console.log(a)
var a=1 //undefined
console.log(b)
let b=1 //报错
3.重复声明
var声明变量时,可以重复声明变量,后声明的同名变量会覆盖之前声明的遍历。const和let不 允许重复声明变量。
var a=1
var a=2
console.log(a)//2
let b=1
let b=2
console.log(a) //报错
4.暂时性死区
在使用let、const命令声明变量之前,该变量都是不可用的。这在语法上,称为*暂时性死区 *。使用var声明的变量不存在暂时性死区。
5.给全局添加属性
浏览器的全局对象是window,Node的全局对象是global。var声明的变量为全局变量, 并且会将该变量添加为全局对象的属性,但是let和const不会。
6.初始值设置
在变量声明时,var 和 let 可以不用设置初始值。而const声明变量必须设置初始值。
const a
console.log(a);//报错
7.指针指向
let和const都是ES6新增的用于创建变量的语法。 let创建的变量是可以更改指针指向(可以重 新赋值)。但const声明的变量是不允许改变指针的指向。