一、var. y+ ^" V; x- T Y4 V' Y
在ES5中,顶层对象的属性和全局变量是等价的,用var声明的变量既是全局变量,也是顶层变量。/ @; k# o' P. j) |& f, N! L
注意:顶层对象,在浏览器环境指的是window对象,在 Node 指的是global对象。 - k: B/ Y' H7 [0 @2 A' O+ o
// var
console.log(a) // undefined
var a = 10
// let
console.log(b) // Cannot access 'b' before initialization
let b = 10
// const
console.log(c) // Cannot access 'c' before initialization
const c = 10
暂时性死区 L' h; ]+ R5 f O8 \' z' E7 R
var不存在暂时性死区,let和const存在暂时性死区,只有等到声明变量的那一行代码出现,才可以获取和使用该变量。 g& j5 }, O6 J R: C% M
// var
console.log(a) // undefined
var a = 10
// let
console.log(b) // Cannot access 'b' before initialization
let b = 10
// const
console.log(c) // Cannot access 'c' before initialization
const c = 10
块级作用域. @+ n( }- v8 C9 s2 g8 |" I& C4 U
var不存在块级作用域,let和const存在块级作用域。 ) a4 U4 t6 j& }4 U M+ X5 c7 S
// var
{
var a = 20
}
console.log(a) // 20
// let
{
let b = 20
}
console.log(b) // Uncaught ReferenceError: b is not defined
// const
{
const c = 20
}
console.log(c) // Uncaught ReferenceError: c is not defined
重复声明' ?( L2 ]) V q- l4 @
var允许重复声明变量,let和const在同一作用域不允许重复声明变量。' Q' j+ O$ d) [2 c8 O+ M
// var
var a = 10
var a = 20 // 20
// let
let b = 10
let b = 20 // Identifier 'b' has already been declared
// const
const c = 10
const c = 20 // Identifier 'c' has already been declared
修改声明的变量 ' [, @5 T+ a' j6 z: i& g7 U) v var和let可以,const声明一个只读的常量。一旦声明,常量的值就不能改变。 8 a/ L+ ^& K/ B9 I
// var
var a = 10
a = 20
console.log(a) // 20
//let
let b = 10
b = 20
console.log(b) // 20
// const
const c = 10
c = 20
console.log(c) // Uncaught TypeError: Assignment to constant variable