ES6之let声明

1、在for循环中用let定义,当前的let只在本轮的循环中有用,每一次i都是一个新的变量;
2、js引擎会记住上一次循环的值,所以每一次i都是在上一次的基础上进行计算。
3、for循环语句中,循环语句是父作用域,而循环体内部是单独的子作用域,如以下代码是没有问题的:

for(let i=0;i<3;i++){
  let i = abc;
  console.log(i);
}
//abc
//abc
//abc
//函数内部的变量i和函数外部的变量i是分离的。

4、所声明的变量一定要在声明后使用,否则报错
5、暂时性死区:只要块级作用域内存在let命令,它所声明的变量就“绑定”(binding)这个区域,不再受外部的影响。

var temp = 'abc';
if(true){
 temp = '123';  //ReferenceError
 let temp;
}
//由于temp绑定这个块级作用域,所以在let声明变量前,对tmp赋值会报错。

const同理:某个区块对这些命令声明的变量,从一开始就形成了封闭作用域。凡是在声明之前就使用这些变量,就会报错。
6、暂时性死区”也意味着typeof不再是一个百分之百安全的操作。作为比较,如果一个变量根本没有被声明,使用typeof反而不会报错,而是会返回undefined。
7、还有另一种死区的形式,比较隐蔽:

function bar(x = y,y = 2){
  return [x,y];
}

这种情况下,x的默认值等于一个参数,而y此时还没有声明,属于死区;
8、还还有一种死区的表现形式,如下:

var x = x; //不报错
let x = x;  //报错
//使用let声明变量时,只要变量在还没有声明完成前使用,就会报错。

9、规定暂时性死区和let、const语句不出现变量提升的作用:
主要是为了减少运行时错误,防止在变量声明前就使用这个变量,从而导致意料之外的行为。
10、let不允许重复声明

function func1(){
  let a = 1;
  var a = 10; 
}  //报错
function func2(){  //报错
  let a = 1;
  let b = 10;
}
//同时,也不能在函数内部同时声明参数
function func3(a){  //报错
  let a = 10; 
}
function func4(a){
  {
    let a = 10;  //不会报错
  }
}
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值