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

区别:1、var声明的变量属于函数作用域,letconst声明的变量属于块级作用域;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 声明一个变量,那么这个变量就属于当前的函数作用域,如果声明是发生在任何函数外的顶层声明,那么这个变量就属于全局作用域。举例说明:

立即学习“Java免费学习笔记(深入)”;

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);//undefinedvar a = 1;

登录后复制

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

var a;console.log(a);//undefineda = 1;

登录后复制

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

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

登录后复制

了解let

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

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

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

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

如下面几个例子所示

let a = 1;console.log(a);//1console.log(b);//Uncaught ReferenceError: b is not definedlet 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 < 10; i++) {    setTimeout(function(){        console.log(i);    },100)};

登录后复制

该代码运行后,会在控制台打印出10个10.若修改为:

for (let i = 0; i < 10; i++) {    setTimeout(function(){        console.log(i);    },100)};

登录后复制

则该代码运行后,就会在控制台打印出0-9.

了解const

const 声明方式,除了具有 let 的上述特点外,其还具备一个特点,即 const 定义的变量,一旦定义后,就不能修改,即 const 声明的为常量。

例如:

const a = 1;console.log(a);//1a = 2;console.log(a);//Uncaught TypeError: Assignment to constant variable.

登录后复制

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

const obj = {a:1,b:2};console.log(obj.a);//1obj.a = 3;console.log(obj.a);//3

登录后复制

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

区别总结

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

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

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

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

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

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至253000106@qq.com举报,一经查实,本站将立刻删除。

发布者:PHP中文网,转转请注明出处:https://www.chuangxiangniao.com/p/2724265.html

(0)
上一篇 2025年3月7日 23:12:19
下一篇 2025年2月19日 04:02:11

AD推荐 黄金广告位招租... 更多推荐

相关推荐

  • JavaScript的三大组成部分是什么

    JavaScript的三大组成部分是:1、ECMAscript;2、文档对象模型DOM;3、浏览器对象模型BOM。其中,ECMAscript是javascript的核心,描述了语言的基本语法和数据类型。 JavaScript的三大组成部分是…

    2025年3月7日
    200
  • JavaScript charAt()方法是什么

    JavaScript charAt()方法是可返回指定位置的字符,语法为【stringObject.charAt(index)】,其中index表示字符串中某个位置的数字,即字符在字符串中的下标。 定义和用法 charAt() 方法可返回指…

    2025年3月7日
    200
  • 详解JS中的垃圾回收和内存泄漏

    程序的运行需要内存。只要程序提出要求,操作系统或者运行时就必须供给内存。所谓的内存泄漏简单来说是不再用到的内存,没有及时释放。为了更好避免内存泄漏,我们先介绍Javascript垃圾回收机制。 在C与C++等语言中,开发人员可以直接控制内存…

    2025年3月7日 编程技术
    200
  • 深入讨论JavaScript中Set对象如何让代码更快

    我确信有很多开发人员坚持使用基本的全局对象:数字,字符串,对象,数组和布尔值。对于许多用例,这些都是需要的。 但是如果想让你的代码尽可能快速和可扩展,那么这些基本类型并不总是足够好。 在本文中,我们将讨论JS 中Set对象如何让代码更快— …

    2025年3月7日
    200
  • javascript中substr和substring的区别是什么

    javascript中substr和substring的区别是:substr是从起始索引号开始提取指定长度的字符串;substring是提取字符串中两个指定索引号之间的字符。 区别介绍: (视频学习分享:javascript视频教程) su…

    2025年3月7日
    200
  • 你所不知道的JavaScript

    JavaScript栏目介绍一些必会操作。 和其他“圈子”里的同学们不一样,前端圈子里的同学们都很热衷于“手写xxx方法”,基本上每天在掘金里都可以看到类似的文章。但是,很多文章(不代表全部,无意冒犯)大都是囫囵吞枣、依葫芦画瓢,经不起推敲…

    2025年3月7日
    200
  • 同时去掉字符串左边和右边空格的函数是什么?

    同时去掉字符串左边和右边空格的函数是“trim()”;trim()函数可用于删除字符串的头尾空白符,空白符包括:空格、制表符tab、换行符等其他空白符等,语法“string.trim()”。 本教程操作环境:windows10系统、java…

    2025年3月7日
    200
  • javascript如何改变原数组

    javascript改变原数组的方法:1、push往数组里面增加东西;2、pop把数组最后一位元素剪切出去;3、unshit是往数组第一位元素前面添加元素;4、shit从数组前面的第一位元素开始删除。 本教程操作环境:windows10系统…

    2025年3月7日 编程技术
    200
  • javascript提高前端代码强大的一些方法,很好!

    javascript栏目介绍提高前端代码强大的一些方法。 免费推荐:JavaScript(视频) 在过去的开发经历中处理了各种奇葩BUG,认识到代码健壮性(鲁棒性)是提高工作效率、生活质量的一个重要指标,本文主要整理了提高代码健壮性的一些思…

    2025年3月7日
    200
  • 详解JavaScript中async/await的使用方法

    ES8 引入的 async/await 在 JavaScript 的异步编程中是一个极好的改进。它提供了使用同步样式代码异步访问 resoruces 的方式,而不会阻塞主线程。然而,它们也存在一些坑及问题。在本文中,将从不同的角度探讨 as…

    2025年3月7日
    200

发表回复

登录后才能评论