let命令
1.基本用法
ES6新增了let命令,用来声明变量。它的用法类似于var,但是所声明的变量,只在let命令所在的代码块内有效。
2.不存在变量提升
let不像var那样,会发生“变量提升”现象。
3.暂时性死区
只要块级作用域内存在let命令,它所声明的变量就“绑定”(binding)这个区域,不再受外部的影响。
4.不允许重复声明
let不允许在相同作用域内,重复声明同一个变量。
块级作用域
1.为什么需要块级作用域?
ES5只有全局作用域和函数作用域,没有块级作用域,这带来很多不合理的场景。第一种场景,内层变量可能会覆盖外层变量。第二种场景,用来计数的循环变量泄露为全局变量。
2.ES6的块级作用域
let实际上为JavaScript新增了块级作用域。
const命令
const也用来声明变量,但是声明的是常量。
一旦声明,常量的值就不能改变。
跨模块常量
const声明的常量只在当前代码块有效。
如果想设置跨模块的常量,应该怎么办呢?
全局对象的属性
全局对象是最顶层的对象,在浏览器环境指的是window对象,在Node.js指的是global对象。在JavaScript语言中,所有全局变量都是全局对象的属性。(Node的情况比较特殊,这一条只对REPL环境适用,模块环境必须显式声明成global的属性。)
ES6规定,var命令和function命令声明的全局变量,属于全局对象的属性;let命令、const命令、class命令声明的全局变量,不属于全局对象的属性。