ES6之------------------let,const

来源:互联网 发布:电力猫网络dns不正常 编辑:程序博客网 时间:2024/05/16 07:08

最近不是太忙,准备仔细研究下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明确规定,如果区块中存在letconst命令,这个区块对这些命令声明的变量,从一开始就形成了封闭作用域。凡是在声明之前就使用这些变量,就会报错。

 

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作为顶层对象所有环境下,都可以从它拿到顶层对象---(提案)


原创粉丝点击