最近不是太忙,准备仔细研究下Es6;持续更新中;
let,const
let不像var那样会发生“变量提升”现象。所以,变量一定要在声明后使用,否则报错。
{
let a = 10;
var b = 1;
}
a //
b //
var a = [];for (let i = 0; i < 10; i++) {
a[i] = function () {
console.log(i);
};
}
a[6](); //
死区:ES6明确规定,如果区块中存在let和const命令,这个区块对这些命令声明的变量,从一开始就形成了封闭作用域。凡是在声明之前就使用这些变量,就会报错。
var tmp = 123;
if (true) {
tmp = 'abc'; //
let tmp;
}
function bar(x = y, y = 2) {
return [x, y];
}
bar(); //
不允许重复声明
function () {
let a = 10;
var a = 1;
}
块级作用域之中,函数声明语句的行为类似于let,块级作用域之外不可引用。
function f() { console.log('I am outside!'); }
(function () {
if (false) {
// 重复声明一次函数f
function f() { console.log('I am inside!'); }
}
f();
}());
考虑到环境导致的行为差异太大,应该避免在块级作用域内声明函数。如果确实需要,也应该写成函数表达式,而不是函数声明语句。
function f() {}
let f = function () {}
do 表达式-----------(目前只提案,还不支持)
let x = do {
let t = f();
t * t + 1; return t;
};
Const 声明一个只读的常量 ; 必须立即初始化
const命令只是保证变量名指向的地址不变,并不保证该地址的数据不变,所以将一个对象声明为常量必须非常小心。---------针对复合类型变量
Object.freeze-------可以将对象冻结
let命令、const命令、class命令声明的全局变量,不属于顶层对象的属性。也就是说,从ES6开始,全局变量将逐步与顶层对象的属性脱钩;
ES5的顶层对象,本身也是一个问题,因为它在各种实现里面是不统一的。
· 浏览器里面,顶层对象是window,但 Node 和 Web Worker 没有window。
· 浏览器和 Web Worker 里面,self也指向顶层对象,但是Node没有self。
· Node 里面,顶层对象是global,但其他环境都不支持。
引入global作为顶层对象,所有环境下,都可以从它拿到顶层对象---(提案)