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开始,全局变量将逐步与顶层对象的属性脱钩。
相关文章推荐
- ECMAScript6学习笔记《二》-----“const命令与let命令”
- ECMAScript6-let与const命令详解
- ECMAScript6笔记:let和const命令
- ECMAScript6-学习笔记(let和const命令)
- ECMAScript6-let与const命令详解
- let和const命令
- ECMAScript 6入门 - let和const命令
- ECMAScript6学习笔记 ——let、const、变量解构赋值
- ECMAScript6(ES6)标准之let、const关键字与块级作用域
- ECMAScript6简介和学习笔记(一) let const 解构
- let和const命令
- 搭建Babel运行环境,Traceur ES6模板,块级作用域,let和const命令
- js变量中有var定义和无var定义的区别,es6中let命令和const命令
- ES6学习笔记(一)--let和const命令
- ES6 之 let和const命令 Symbol Promise对象
- es6学习篇之 let和const命令 、变量的解构赋值
- ECMAScript6的let命令
- ES6入门——let和const命令
- React 语法之let和const命令
- ES6之let(理解闭包)和const命令