Js中var,let,const的区别你知道吗
作者:Cirrod 发布时间:2024-05-09 15:07:50
一:区别:
1、var声明的变量属于函数作用域,而let和const声明的变量属于块级作用域;(js作用域在上篇文章)
2、var声明的变量存在变量提升,而let和const没有
3、var声明的变量可以重复声明,而在同一块级作用域,let变量不能重新声明,const常量不能修改(对象的属性和方法,数组的内容可以修改)
二:var声明的作用域
1. 使用var声明的变量,这个变量属于当前的函数作用域,如果变量的声明在任何函数外,那么这个变量就属于全局作用域
var a = 1; //此处声明的变量a为全局变量
function foo(){
var a = 2;//此处声明的变量a为函数foo的局部变量
console.log(a);//2
}
foo();
console.log(a);//1
2.如果在声明变量时,省略 var 的话,该变量就会变成全局变量,如全局作用域中存在该变量,就会更新其值
var a = 1; //此处声明的变量a为全局变量
function foo(){
a = 2;//此处的变量a也是全局变量
console.log(a);//2
}
foo();
console.log(a);//2
三:var声明的变量提升
1.var的声明会在js预解析时把var的声明提升到当前作用域的最前面,意思是是指无论 var 出现在一个作用域的哪个位置,这个声明都属于当前的整个作用域,在其中到处都可以访问到。只有变量声明才会提升,对变量赋值并不会提升
console.log(a);//undefined
var a = 1;
相当于执行以下代码
var a;
console.log(a);//undefined
a = 1;
四、let声明
1.let 声明的变量具有块作用域的特征。
2.在同一个块级作用域,不能重复声明变量。
function foo(){
let a = 1;
let a = 2;//Uncaught SyntaxError: Identifier 'a' has already been declared
}
3.let 声明的变量不存在变量提升,换一种说法,就是 let 声明存在暂时性死区(TDZ)。
let a = 1;
console.log(a);//1
console.log(b);//Uncaught ReferenceError: b is not defined
let b = 2;
(此时变量b的声明不会提升到当前作用域的前面)
五:彻底区分var和let声明变量(作用域区别)
1.var声明
for (var i = 0; i < 10; i++) {
setTimeout(function(){
console.log(i);
},100)
};
(1.此时的var声明的变量i属于函数作用域,声明又不在函数里,所以i属于全局变量
2.此时的定时器函数属于异步函数,隔100毫秒才会执行,而这100毫秒的时间内,for循环已经循环结束,全局变量i已经为10
3.相当于代码执行
{
var i = 0;
// 第一次循环
{
setTimeout(() => {
//延时器属于异步函数,不会立即执行,
//经过1s后,循环已经结束,全局变量i已经变成10
console.log(i);
}, 1000)
i++
}
// 第二次循环
{
setTimeout(() => {
//var声明的变量i没有块级作用域,所以可以访问第一次循环体内的变量i,
//同样,1s后,循环已经结束,全局变量i已经变成10
console.log(i);
}, 1000)
i++
}
.....
}
最后代码的执行后,会在控制台打印出10个10)
ps:主要的原因是var声明的变量的没有块级作用域
2.let 声明
使用闭包原理解决上例中var声明变量的不具有块级作用域的问题:
for (var i = 1; i <= 5; i++) {
//i=0 第一轮循环
(function (i) {
// 立即执行函数执行,形成一个私有的函数上下文
//形参i是属于立即执行函数的局部变量,第一轮循环时相当于let i=0
//由于立即执行函数的参数i被下一级的延时器回调函数上下文所引用,所以会产生闭包,
// 从而形成块级作用域,保护了每一次循环的i,也就是闭包的特点:变量私有化
setTimeout(() => {
// 延时器回调函数执行,也会形成一个私有的函数上下文
console.log(i);//由于当前延时器回调函数上下文引用了
// 上一级立即执行函数的参数i(立即执行函数的局部变量),
//所以此时会产生闭包,立即执行函数的参数i会一直保存在内存中供延时器回调函数使用
}, 5000)
})(i)//把每一轮循环全局的i的值作为实参传递给立即执行函数的私有上下文,第一轮传递的是0
}
使用let声明的变量具有块级作用域
for (let i = 0; i < 10; i++) {
// 每一轮都会形成一个私有的块级作用域,并且有一个私有的变量i,分别存储每一轮循环的索引
setTimeout(function(){
console.log(i);
},100)
};
PS:这是因为闭包的机制,但是因为let的块作用域是浏览器底层机制实现的,比我们自己创建的闭包性能要好一些
代码执行后,则该代码运行后,就会在控制台打印出0-9. )
六:const 声明
1.const 声明方式,除了具有 let 的上述特点外,其还具备一个特点,即 const 定义的变量,一旦定义后,就不能修改,即 const 声明的为常量。
const a = 1;
console.log(a);//1
a = 2;
console.log(a);//Uncaught TypeError: Assignment to constant variable.
2.但是,并不是说 const 声明的变量其内部内容不可变,如:
const obj = {a:1,b:2};
console.log(obj.a);//1
obj.a = 3;
console.log(obj.a);//3
所以准确的说,是 const 声明创建一个值的只读引用。但这并不意味着它所持有的值是不可变的,只是变量标识符不能重新分配。
(我的理解是如果是简单数据类型,const声明的变量保存的值就是变量的值,是不可以修改,但如果是复杂数据类型(对象,数组等)const只是保存的是复杂数据类型的地址,只是确保地址不可变,但地址指向的内容是可以变的)
来源:https://blog.csdn.net/h18377528386/article/details/122617959


猜你喜欢
- 今天有一位同学给了我一个excel文件,要求读取某些行,某些列,然后我试着做了一个demo,这里分享出来,希望能帮到大家:首先安装xlrd:
- 前言每种编程语言为了表现出色,并且实现卓越的性能,都需要有大量编译器级与解释器级的优化。由于字符串是任何编程语言中不可或缺的一个部分,因此,
- 通过python+splinter,实现在12306网站刷票并自动购票流程(无法自动识别验证码)。此类程序只是提高了12306网站的 <
- 1.Apache2.2\conf\httpd.conf中释放: Include conf/extra/httpd-vhosts.conf(去
- 使用“发送测试电子邮件”对话框来测试使用特定配置文件发送邮件的能力。过程发送测试电子邮件1.使用对象
- 前言字符串是 字符的序列 。字符串基本上就是一组单词。我几乎可以保证你在每个Python程序中都要用到字符串,所以请特别留心下面这部分的内容
- 在做自动化测试时,遇到两种情况需要判断usb是否已连接上(注,本文仅针对用adb命令来control手机)一种是在开测时(前提是同时要测试多
- 思路:遍历文件夹下面的文件夹如果文件夹名称等于".svn",则修改文件夹的属性(因为".svn"的文
- 利用numpy库(缺点:有缺失值就无法读取)读:import numpy my_matrix = numpy.loadtxt(open(&q
- pyecharts介绍pyecharts 是一个用于生成 Echarts 图表的类库。Echarts 是百度开源的一个数据可视化 JS 库。
- mysql行转列、列转行 语句不难,不做多余解释了,看语句时,从内往外一句一句剖析行转列 &nb
- 很多时候关心的是优化SELECT 查询,因为它们是最常用的查询,而且确定怎样优化它们并不总是直截了当。相对来说,将数据装入数据库是直截了当的
- 通常我们提交代码一般都是 git add ,git commit -m, git push的这么个流程。添加到暂存区
- 在python中进行两个整数相除的时候,在默认情况下都是只能够得到整数的值解决方法:1. 修改被除数的值为带小数点的形式即可得到浮点值2.在
- Pelican 介绍首先看看 Pelican 的一些主要特性: Python实现,开放源码 &
- Web Accessibility Initiative Accessible Rich Internet Applications认识AR
- Python语言与Perl,C和Java等语言有许多相似之处。但是,也存在一些差异。在本章中我们将来学习Python的基础语法,让你快速学会
- 数据类型计算机顾名思义就是可以做数学计算的机器,因此,计算机程序理所当然地可以处理各种数值。但是,计算机能处理的远不止数值,还可以处理文本、
- 栈(stack)栈又称之为堆栈是一个特殊的有序表,其插入和删除操作都在栈顶进行操作,并且按照先进后出,后进先出的规则进行运作。如下图所示例如
- 如下所示:alist=[1,2]] >>>[1,2] alist.append([3,4]) >>>[1