ES6中let和var、const定义变量的区别
注意:作用域只有全局作用域和函数作用域(函数作用域是在函数内,for和if不是函数,他们的大括号内不算函数作用域)
(1)var
1、var 限制函数作用域,let限制块级作用域
2、JavaScript没有块级作用域
3、var 声明的变量,无论在哪里声明,都会被当成在当前作用域顶部声明的变量(作用域为函数内)
var i=10;
for(var i=0;i<6;i++){
//do nothing
}
console.log(i)//6
(2)let
let 块级作用域(作用范围是:函数内部或{}内部【包括if,for等的{}内】)
**也就是说:**let的作用域在{}内,无论是什么的{},只要是{}都算
var i=10;
for(let i=0;i<6;i++){
//do nothing
}
console.log(i)//10
(3)const
1、const定义常量
定义后常量不可被更改
const name="aa"
name="b"
console.log(name)//报错
2、const定义对象
对象的引用不能修改,但是对象的属性值可以修改
const obj={name:"a"}
obj.name="b"
console.log(obj)//{name: 'b'}
obj={name:"cc"}
console.log(obj)//报错
obj={a:"aaa"}
console.log(obj)//报错
3、冻结对象:防止修改对象的属性值
const obj=Object.freeze({name:"aa"})
obj.name="tom"
console.log(obj)//{name: 'aa'}