JavaScript中var,let和const的区别
前言
在es6出现之前,javaScript中声明变量就只通过var 关键字,函数声明是通过function关键字,而在es6之后,声明的方式有var ,let,const,function,class,本文主要讨论var ,let ,和const之间的区别
一.var
如果使用关键字 var 声明一个变量,那么这个变量就属于当前的函数作用域,如果声明是发生在任何函数外的顶层声明,那么这个变量就属于全局作用域。举例说明:
var a = 1; //此处声明的变量a为全局变量
function foo(){
var a = 2;//此处声明的变量a为函数foo的局部变量
console.log(a);//2
}
foo();
console.log(a);//1
如果在声明变量时,省略 var 的话,该变量就会变成全局变量,如全局作用域中存在该变量,就会更新其值。如:
var a = 1; //此处声明的变量a为全局变量
function foo(){
a = 2;//此处的变量a也是全局变量
console.log(a);//2
}
foo();
console.log(a);//2
提升是指无论 var 出现在一个作用域的哪个位置,这个声明都属于当前的整个作用域,在其中到处都可以访问到。注意只有变量声明才会提升,对变量赋值并不会提升。如下例所示:
console.log(a);//undefined
var a = 1;
var a;
console.log(a);//undefined
a = 1;
而如果对未声明过的变量进行操作,就会报错
二.let
1.声明的变量不会挂在window中,不会造成全局变量的污染
2.新增一个块级作用域,以前有函数作用域和全局作用域
let n = 10;
if(true){
let n = 50;
}
console.log(n);//10
3.不允许重复声明
function foo(){
let a = 1;
let a = 2;//Uncaught SyntaxError: Identifier 'a' has already been declared
}
4.不会有声明提前
let a = 1;
console.log(a);//1
console.log(b);//Uncaught ReferenceError: b is not defined
let b = 2;
三.const
const 声明方式,除了具有 let 的上述特点外,其还具备一个特点,
1.const 定义的变量,一旦定义后,就不能修改,即 const 声明的为常量。
const a = 1;
console.log(a);//1
a = 2;
console.log(a);//Uncaught TypeError: Assignment to constant variable.
2.的声明和赋值必须一致完成,并且后期不允许改变存储地址
const obj = {a:1,b:2};
console.log(obj.a);//1
obj.a = 3;
console.log(obj.a);//3
四.总结
- var 声明的变量属于函数作用域,let 和 const 声明的变量属于块级作用域;
- var 存在变量提升现象,而 let 和 const 没有此类现象;
- var 变量可以重复声明,而在同一个块级作用域,let 变量不能重新声明,const 变量不能修改。