(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保证的并不是变量的值不动,而是变量指向的内存地址不得改动
好啦,以上就是我本次分享的全部内容啦,如果你觉得我的文章对你有一丢丢帮助,那么请不要吝啬你的赞
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)