1、var 声明的变量会挂载在window上。
var a = 1
console.log(a, window.a) // 1 1
let b = 2
console.log(b, window.b) // 2 undefined
const c = 3
console.log(c, window.c) // 3 undefined
2、var 生命变量存在变量提升。
console.log(v) // undefined ===> a已声明但此处拿不到值,默认得到undefined
var v = 1
console.log(l) // 报错,找不到 b
let l = 2
console.log(c)
const c = 3 // 报错,找不到 b
3、let、const 块作用域(作用域外部访问不到)
{
var a = 1
let b = 2
const c = 3
}
console.log(a) // 1
console.log(b) // b is not defined
console.log(c) // c is not defined
4、同一作用域 let/const 不能声明同名变量,var 可以
var a = 100
console.log(a) // 100
var a = 10
console.log(a) // 10
let a = 100
let a = 10
// 控制台报错,Identifier 'a' has already been declared ===> 标识符a已经被声明了。
5、暂存死区
在当前块作用域中存在a使用let/const声明的情况下,给a赋值10时,只会在当前作用域找变量a,而这时,还未到声明时候,所以控制台Error:a is not defined
var a = 100;
{
a = 10;
let a = 1; // 控制台报错:Cannot access 'a' before initialization
}
6、const
1)一旦声明必须赋值,不能使用null占位。
2)如果是基础类型,声明后不能再修改。
3)如果声明的是复合类型数据,可以修改其属性值。
const a = 100;
const list = [];
list[0] = 10;
console.log(list); // [10]
const obj = {a:100};
obj.name = 'apple';
obj.a = 10000;
console.log(obj); // {a:10000,name:'apple'}