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

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开始,全局变量将逐步与顶层对象的属性脱钩。

你可能感兴趣的:(JS)