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

最近不是太忙,准备仔细研究下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作为顶层对象所有环境下,都可以从它拿到顶层对象---(提案)


  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 2
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值