其它情况,const与let一致。2 ]* V: y( y v5 y0 f 四、区别8 E+ a, l2 J) v0 T4 i! x
var、let、const三者区别可以围绕下面五点展开:9 S U) Q. _6 L4 n
变量提升 ( |+ V7 Q7 _% ~& C- P var声明的变量存在变量提升,即变量可以在声明之前调用,值为undefined。let和const不存在变量提升,即它们所声明的变量一定要在声明后使用,否则报错。 4 u3 O! _ f. J' |3 Y8 a/ D
// 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
暂时性死区% [, ?3 Y0 F+ g1 z; D
var不存在暂时性死区,let和const存在暂时性死区,只有等到声明变量的那一行代码出现,才可以获取和使用该变量。 ) S1 b* D2 u, A0 \; z$ w
// 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
块级作用域; ^+ U" U* b8 P1 R
var不存在块级作用域,let和const存在块级作用域。 : z, E4 S, q1 c/ c/ T' H; n
// 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
重复声明 0 P, p; C# A6 I3 Z var允许重复声明变量,let和const在同一作用域不允许重复声明变量。- `* C% W6 ~( s3 {& b! N- n+ V0 Z
// 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
修改声明的变量2 G" f5 w2 B1 _) l5 @
var和let可以,const声明一个只读的常量。一旦声明,常量的值就不能改变。2 A4 N# N9 c9 h' P8 f' s: O
// 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
使用' [3 m2 e" @9 z; O
能用const的情况尽量使用const,其他情况下大多数使用let,避免使用var。