概述
在看了别人的文章后简单总结了下
let和const命令
let
和const
命令是ES6新增的命令,用来声明变量,它的用法类似于var。
1.作用域
被let
和const
命令声明的变量,只在let命令所在的代码块内生效,代码块外无法访问;
ES6 明确规定,如果区块中存在let
和const
命令,这个区块对这些命令声明的变量,从一开始就形成了封闭作用域。凡是在声明之前就使用这些变量,就会报错。
2.变量提升
与var
不同,let
和const
声明的变量,不会发生“变量提升”现象,即变量不能在声明之前使用,一旦使用就会报错。
3.暂时性死区
在代码块内,使用let
和const
命令声明变量之前,该变量都是不可用的。这在语法上,称为“暂时性死区”(temporal dead zone,简称 TDZ)。
4.重复声明
被let
和const
声明的变量不可重复声明。
在ES6之前,JavaScript只有全局作用域和函数作用域,let
命令实际上增加了块级作用域。块级作用域的应用场景:
1.在函数作用域内声明变量
2.在for循环中声明循环变量
const
声明一个只读的常量。一旦声明,常量的值就不能改变。
const
实际上保证的,并不是变量的值不得改动,而是变量指向的那个内存地址所保存的数据不得改动。对于简单类型的数据(数值、字符串、布尔值),值就保存在变量指向的那个内存地址,因此等同于常量。但对于复合类型的数据(主要是对象和数组),变量指向的内存地址,保存的只是一个指向实际数据的指针,const
只能保证这个指针是固定的(即总是指向另一个固定的地址),至于它指向的数据结构是不是可变的,就完全不能控制了。
最后
以上就是慈祥哑铃为你收集整理的ES6let和const解释的全部内容,希望文章能够帮你解决ES6let和const解释所遇到的程序开发问题。
如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。
发表评论 取消回复