在前端面试中,特别是前端实习生的面试问题中,对于ES6的考查上,var、let、const这三种变量声明方式的异同点几乎是必考的,本文就来分析一下三者之间有什么区别。
一、前言
在ES6(ES2015)出现之前,JavaScript中声明变量只有通过var
关键字,函数声明是通过 function
关键字,而ES6出现后,声明的方式有var
、let
、const
、function
、 class
,本文主要讨论 var
、let
和 const
之间的区别。
二、var
如果使用关键字var
声明一个变量,那么这个变量就属于当前的函数作用域,如果声明是发生在任何函数外的顶层声明,那么这个变量就属于全局作用域。举例说明:
1 | var a = 1; //此处声明的变量a为全局变量 |
var
的话,该变量就会变成全局变量,如全局作用域中存在该变量,就会更新其值。如:1 | var a = 1; //此处声明的变量a为全局变量 |
var
声明的变量存在提升(hoisting)。三、提升
提升是指无论var
出现在一个作用域的哪个位置,这个声明都属于当前的整个作用域,在其中到处都可以访问到。注意只有变量声明才会提升,对变量赋值并不会提升。如下例所示:
1 | console.log(a); //undefined |
1 | var a; |
1 | console.log(b); //假设b未声明过,Uncaught ReferenceError: b is not defined |
四、let
let
声明的变量,具有如下几个特点:
let
声明的变量具有块作用域的特征。- 在同一个块级作用域,不能重复声明变量。
let
声明的变量不存在变量提升,换一种说法,就是let
声明存在暂时性死区(TDZ)。
如下面几个例子所示
1 | let a = 1; |
1 | function foo() { |
var
和let
的一个例子:1 | for (var i = 0; i < 10; i++) { |
1 | for (let i = 0; i < 10; i++) { |
五、const
const
声明方式,除了具有let
的上述特点外,其还具备一个特点,即const
定义的变量,一旦定义后,就不能修改,即const
声明的为常量。
例如:
1 | const a = 1; |
const
声明的变量其内部内容不可变,如:1 | const obj = { a: 1, b: 2 }; |
const
声明创建一个值的只读引用。但这并不意味着它所持有的值是不可变的,只是变量标识符不能重新分配。六、总结
var
声明的变量属于函数作用域,let
和const
声明的变量属于块级作用域;var
存在变量提升现象,而let
和const
没有此类现象;var
变量可以重复声明,而在同一个块级作用域,let
变量不能重新声明,const
变量不能修改。