JavaScript中var,与常量有哪些区别

  介绍

小编给大家分享一下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,与常量有哪些区别