小编给大家分享一下JavaScript中var,让与常量有哪些区别,希望大家阅读完这篇文章后大所收获、下面让我们一起去探讨吧!
区别:1,var声明的变量属于函数作用域,让和const声明的变量属于块级作用域;2,var存在变量提升现象,而让和const没有;3、var变量可以重复声明,而在同一块级作用域,让变量不能重新声明,const变量不能修改。
引用>在ES6 (ES2015)出现之前,JavaScript中声明变量就只有通过var关键字,函数声明是通过函数关键字,而在ES6之后,声明的方式有var,让,const,函数,类,本文主要讨论var,让和const之间的区别。
<>强了解var 强>
如果使用关键字var声明一个变量,那么这个变量就属于当前的函数作用域,如果声明是发生在任何函数外的顶层声明,那么这个变量就属于全局作用域。举例说明:
var=1;//此处声明的变量一个为全局变量 函数foo () { var=2;//此处声明的变量一个为函数foo的局部变量 console.log (a);//2 } foo (); console.log (a);//1如果在声明变量时,省略var的话,该变量就会变成全局变量,如全局作用域中存在该变量,就会更新其值。如:
var=1;//此处声明的变量一个为全局变量 函数foo () {=2;//此处的变量一个也是全局变量 console.log (a);//2 } foo (); console.log (a);//2注意:var声明的变量存在提升(吊装)。
<>强了解“提升”强>
提升是指无论var出现在一个作用域的哪个位置,这个声明都属于当前的整个作用域,在其中到处都可以访问到。注意只有变量声明才会提升,对变量赋值并不会提升。如下例所示:
console.log (a);//定义 var=1;该代码段跟下列代码段是一样的逻辑:
var; console.log (a);//定义=1;而如果对未声明过的变量进行操作,就会报错
console.log (b);//假设b未声明过,未捕获ReferenceError: b没有定义<>强了解让强>
让声明的变量,具有如下几个特点:
<李>
让声明的变量具有块作用域的特征。
李> <李>在同一个块级作用域,不能重复声明变量。
李> <李>让声明的变量不存在变量提升,换一种说法,就是让声明存在暂时性死区(TDZ)。
李>如下面几个例子所示
让=1; console.log (a);//1 console.log (b);//未捕获ReferenceError: b没有定义 让b=2;函数foo () { 让=1; 让=2;//未捕获SyntaxError:标识符& # 39;一个# 39;已经宣布 }以下是一个经典的关于var和我们的一个例子:
为(var=0;我& lt;10;我+ +){ setTimeout(函数(){ console.log(我); }, 100) };该代码运行后,会在控制台打印出10个10。若修改为:
,(让我=0;我& lt;10;我+ +){ setTimeout(函数(){ console.log(我); }, 100) };则该代码运行后,就会在控制台打印出0 - 9。
<>强了解const 强>
const声明方式,除了具有让的上述特点外,其还具备一个特点,即常量定义的变量,一旦定义后,就不能修改,即const声明的为常量。
例如:
const=1; console.log (a);//1=2; console.log (a);//未捕获TypeError:分配常数变量。但是,并不是说const声明的变量其内部内容不可变,如:
const obj={1, b: 2}; console.log (obj.a);//1 obj。=3; console.log (obj.a);//3所以准确的说,是const声明创建一个值的只读引用。但这并不意味着它所持有的值是不可变的,只是变量标识符不能重新分配。
<强>区别总结强>
<李>
var声明的变量属于函数作用域,让和const声明的变量属于块级作用域;
李> <李>var存在变量提升现象,而让和const没有此类现象;
李> <李>var变量可以重复声明,而在同一个块级作用域,让变量不能重新声明,const变量不能修改。
李>看完了这篇文章,相信你对JavaScript中var,让与常量有哪些区别有了一定的了解,想了解更多相关知识,欢迎关注行业资讯频道,感谢各位的阅读!
JavaScript中var,与常量有哪些区别