es6 :let const 解构赋值

es6 :let const 解构赋值,第1张

let和const是es6新增的两个变量声明关键字,与var的不同点在于:

(1)let和const都是块级作用域,在{}内有效,这点在for循环中非常有用,只在循环体内有效。var为函数作用域。

(2)使用let和const声明的变量,不存在变量提升,必须先声明再使用。使用var声明的变量可以先使用再定义。

(3)不可重复声明。不可以重复赋值 一旦用var,let或者const声明过的变量,再次用let或者const声明时会报错,函数的参数名如果用let或者const在函数体内声明同名的参数时,也会报错。

const特殊要点:

(1)const顾名思义常量,这里的常量指的是在定义就确定其值,并且这个值只读,不可以修改

(2)使用const声明的变量,一旦声明需要立即初始化,只声明的变量无法用const,const a编译会报错;并且一旦初始化,就不能改变。

(3)const用于定义一个复合型对象或者数组时,只是对对象或者数组本身不可赋值,但依然可以为对象添加属性或者为数组push元素。

const不可以重复赋值

数组的解构是按照变量的顺序进行赋值的

在es6内部 使用严格相等运算符(===)判断一个位置是否有值,所以当一个数组成员严格等于undefined。默认值才会生效

null 是数组成员 默认值不会生效

对象解构的主要依据是对象的属性,对象的属性没有次序,变量必须与属性同名,才能取到正确的值

函数参数的解构同样要求模式匹配,函数定义时的参数的数据类型和调用时传入的参数类型保持一致。

字符串可以转化为一个具有类似数组的对象。

我们都知道const一般声明一个只读的常量,声明之后就不能修改了,并且声明时必须初始化

那大家有没有遇到这样的情况

奇怪,上面的例子明明改变了变量的值,为什么没有报错?

下面我们就探究一下const的本质

其实const保证的并不是变量的值不动,而是变量指向的内存地址不得改动

可能有点抽象,我们来细细分析一下const声明的全过程

js会将存储‘word’字符串的地址赋给message,而message又是用const定义的变量,不可以改变变量里存储的内存地址,这时就会❌报错

而当遇到下面这种情况

则可以理解为

dog中存储的是对象的房间号(内存地址)

dog.name= 'wangcai',在给对象添加属性的过程,并没有改变这个地址,所以结果正常显示

const保证的并不是变量的值不动,而是变量指向的内存地址不得改动

好啦,以上就是我本次分享的全部内容啦,如果你觉得我的文章对你有一丢丢帮助,那么请不要吝啬你的赞

欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/bake/11743786.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-05-18
下一篇 2023-05-18

发表评论

登录后才能评论

评论列表(0条)

保存