您的位置:首页 > 其它

ECMAScript6学习笔记——let和const命令

2017-04-03 22:05 405 查看

let命令

       let命令,用来声明变量

所声明的变量,只在let命令所在的代码块内有效。
不存在变量提升,let命令改变了语法行为,它所声明的变量一定要在声明后使用,否则报错。
暂时性死区

          ES6 规定暂时性死区和let、const语句不出现变量提升,主要是为了减少运行时错误,防止在变量声明前就使用这个变量,从而导致意料之外的行为。暂时性死区的本质就是,只要一进入当前作用域,所要使用的变量就已经存在了,但是不可获取,只有等到声明变量的那一行代码出现,才可以获取和使用该变量。

         只要块级作用域内存在let命令,它所声明的变量就“绑定”(binding)这个区域,不再受外部的影响。
不允许重复声明

      let不允许在相同作用域内,重复声明同一个变量。因此,不能在函数内部重新声明参数。

const 命令

const声明一个只读的常量。一旦声明,常量的值就不能改变。
const一旦声明变量,就必须立即初始化,不能留到以后赋值。
只在声明所在的块级作用域内有效。
const命令声明的常量也是不提升,同样存在暂时性死区,只能在声明的位置后面使用。

ES6 声明变量的六种方法

var命令和function命令;let和const命令;import命令和class命令。

ES5之中,顶层对象的属性与全局变量是等价的。var命令和function命令声明的全局变量,依旧是顶层对象的属性;另一方面规定,let命令、const命令、class命令声明的全局变量,不属于顶层对象的属性。也就是说,从ES6开始,全局变量将逐步与顶层对象的属性脱钩。
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: