登录  /  注册
首页 > web前端 > js教程 > 正文

JavaScript中var,let与const的区别是什么?

青灯夜游
发布: 2020-11-13 10:54:49
原创
16016人浏览过

区别:1、var声明的变量属于函数作用域,let和const声明的变量属于块级作用域;2、var存在变量提升现象,而let和const没有;3、var变量可以重复声明,而在同一块级作用域,let变量不能重新声明,const变量不能修改。

JavaScript中var,let与const的区别是什么?

推荐教程:《JavaScript视频教程

在ES6(ES2015)出现之前,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 声明的变量存在提升(hoisting)。

了解“提升”

提升是指无论 var 出现在一个作用域的哪个位置,这个声明都属于当前的整个作用域,在其中到处都可以访问到。注意只有变量声明才会提升,对变量赋值并不会提升。如下例所示:

console.log(a);//undefined
var a = 1;
登录后复制

该代码段跟下列代码段是一样的逻辑:

var a;
console.log(a);//undefined
a = 1;
登录后复制

而如果对未声明过的变量进行操作,就会报错

console.log(b);//假设b未声明过,Uncaught ReferenceError: b is not defined
登录后复制

了解let

let 声明的变量,具有如下几个特点:

  • let 声明的变量具有块作用域的特征。

  • 在同一个块级作用域,不能重复声明变量。

  • let 声明的变量不存在变量提升,换一种说法,就是 let 声明存在暂时性死区(TDZ)。

如下面几个例子所示

let a = 1;
console.log(a);//1
console.log(b);//Uncaught ReferenceError: b is not defined
let b = 2;
登录后复制
function foo(){
    let a = 1;
    let a = 2;//Uncaught SyntaxError: Identifier 'a' has already been declared
}
登录后复制

以下是一个经典的关于 var 和 let 的一个例子:

for (var i = 0; i <p>该代码运行后,会在控制台打印出10个10.若修改为:</p><pre class="brush:php;toolbar:false">for (let i = 0; i <p>则该代码运行后,就会在控制台打印出0-9.</p><p><strong>了解const</strong></p><p>const 声明方式,除了具有 let 的上述特点外,其还具备一个特点,即 const 定义的变量,一旦定义后,就不能修改,即 const 声明的为常量。</p><p>例如:</p><pre class="brush:php;toolbar:false">const a = 1;
console.log(a);//1
a = 2;
console.log(a);//Uncaught TypeError: Assignment to constant variable.
登录后复制

但是,并不是说 const 声明的变量其内部内容不可变,如:

const obj = {a:1,b:2};
console.log(obj.a);//1
obj.a = 3;
console.log(obj.a);//3
登录后复制

所以准确的说,是 const 声明创建一个值的只读引用。但这并不意味着它所持有的值是不可变的,只是变量标识符不能重新分配。

区别总结

  • var 声明的变量属于函数作用域,let 和 const 声明的变量属于块级作用域;

  • var 存在变量提升现象,而 let 和 const 没有此类现象;

  • var 变量可以重复声明,而在同一个块级作用域,let 变量不能重新声明,const 变量不能修改。

更多编程相关知识,请访问:编程教学!!

以上就是JavaScript中var,let与const的区别是什么?的详细内容,更多请关注php中文网其它相关文章!

智能AI问答
PHP中文网智能助手能迅速回答你的编程问题,提供实时的代码和解决方案,帮助你解决各种难题。不仅如此,它还能提供编程资源和学习指导,帮助你快速提升编程技能。无论你是初学者还是专业人士,AI智能助手都能成为你的可靠助手,助力你在编程领域取得更大的成就。
来源:php中文网
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
作者最新文章
最新问题
关于CSS思维导图的课件在哪? 课件
凡人来自于2024-04-16 10:10:18
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习
PHP中文网抖音号
发现有趣的

Copyright 2014-2024 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号