const、let、var 的区别

2020-06-10  本文已影响0人  JosephScript

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、letconst 块作用域(作用域外部访问不到)

{
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'}
上一篇 下一篇

猜你喜欢

热点阅读