本文摘自PHP中文网,作者青灯夜游,侵删。
区别:1、var声明的变量属于函数作用域,let和const声明的变量属于块级作用域;2、var存在变量提升现象,而let和const没有;3、var变量可以重复声明,而在同一块级作用域,let变量不能重新声明,const变量不能修改。
推荐教程:《JavaScript视频教程》
在ES6(ES2015)出现之前,JavaScript中声明变量就只有通过 var 关键字,函数声明是通过 function 关键字,而在ES6之后,声明的方式有 var 、 let 、 const 、 function 、 class ,本文主要讨论 var 、 let 和 const 之间的区别。
了解var
如果使用关键字 var 声明一个变量,那么这个变量就属于当前的函数作用域,如果声明是发生在任何函数外的顶层声明,那么这个变量就属于全局作用域。举例说明:
1 2 3 4 5 6 7 |
|
如果在声明变量时,省略 var 的话,该变量就会变成全局变量,如全局作用域中存在该变量,就会更新其值。如:
1 2 3 4 5 6 7 |
|
注意:var 声明的变量存在提升(hoisting)。
了解“提升”
提升是指无论 var 出现在一个作用域的哪个位置,这个声明都属于当前的整个作用域,在其中到处都可以访问到。注意只有变量声明才会提升,对变量赋值并不会提升。如下例所示:
1 2 |
|
该代码段跟下列代码段是一样的逻辑:
1 2 3 |
|
而如果对未声明过的变量进行操作,就会报错
1 |
|
了解let
let 声明的变量,具有如下几个特点:
let 声明的变量具有块作用域的特征。
在同一个块级作用域,不能重复声明变量。
let 声明的变量不存在变量提升,换一种说法,就是 let 声明存在暂时性死区(TDZ)。
如下面几个例子所示
1 2 3 4 |
|
1 2 3 4 |
|
以下是一个经典的关于 var 和 let 的一个例子:
1 2 3 4 5 |
|
该代码运行后,会在控制台打印出10个10.若修改为:
1 2 3 4 5 |
|
则该代码运行后,就会在控制台打印出0-9.
了解const
const 声明方式,除了具有 let 的上述特点外,其还具备一个特点,即 const 定义的变量,一旦定义后,就不能修改,即 const 声明的为常量。
例如:
1 2 3 4 |
|
但是,并不是说 const 声明的变量其内部内容不可变,如:
1 2 3 4 |
|
所以准确的说,是 const 声明创建一个值的只读引用。但这并不意味着它所持有的值是不可变的,只是变量标识符不能重新分配。
区别总结
var 声明的变量属于函数作用域,let 和 const 声明的变量属于块级作用域;
var 存在变量提升现象,而 let 和 const 没有此类现象;
var 变量可以重复声明,而在同一个块级作用域,let 变量不能重新声明,const 变量不能修改。
更多编程相关知识,请访问:编程教学!!
以上就是JavaScript中var,let与const的区别是什么?的详细内容,更多文章请关注木庄网络博客!
相关阅读 >>
更多相关阅读请进入《javascript》频道 >>
Vue.js 设计与实现 基于Vue.js 3 深入解析Vue.js 设计细节
本书对 Vue.js 3 技术细节的分析非常可靠,对于需要深入理解 Vue.js 3 的用户会有很大的帮助。——尤雨溪,Vue.js作者