let
1、所声明的变量只在let所在的代码块中有效。例:
{
var attr1 = 'a'
let attr2 = 'b'
}
console.log(attr1)// a
console.log(attr2)// 报错
2、不存在变量提升
console.log(attr1)//undefined
var attr1 = 'a'
console.log(attr2)//报错
let attr2 = 'b'
3、存在暂时性死区: ES6中规定如果区块中存在let、const命令,区块中对这些命令声明的变量一开始就形成了封闭作用域。凡是在声明前使用这些变量都会报错。
var attr1 = 'hello'
if (true){
console.log(attr1)//报错
let attr1 = 'world'
console.log(attr1)
}
4、let命令不允许在相同作用域内声明相同的变量
{
var attr1 = 'a'
let attr2 = 'b'//报错
}
5、let只能存在于当前作用域的顶层
{
if(true){
let x = 'test'
}
if(true)let y = 666 // 报错 因为 y 没有出现在当前作用域的顶层
}
const
1、const声明的值不能修改,const在声明的时候就必须初始化。
2、const声明常量的作用域只在声明所在代码块中有效。
3、const声明的常量不存在提升。和let一样存在暂时性死区。
ES6中声明变量的几种方式
ES6中可以使用 var、function、let、import、class声明变量。其中前两种在ES5中就支持。
本文详细解析了ES6中变量声明的方式,包括let和const的特点与用法,如作用域限制、变量提升、暂时性死区等,以及与ES5中var的对比。
289

被折叠的 条评论
为什么被折叠?



