ES6-块级作用域

1. 为什么需要块级作用域

        ES6之前只有全局作用域和局部作用域(函数作用域),没有块级作用域,会带来很多不合理的情况。

第一:内层变量可能会覆盖外层变量

// 1.内部变量可能会覆盖外部变量
   var num = 100
   function fn() {
       console.log(num);
       if(true){
           var num = 200;
       }
   }
   fn() //undefined

这段代码的原意是: if语句外部使用外层的num, if语句的内部使用内层的num,但是由于函数fn的定义的num存在变量提升,覆盖了外层的num变量,所以输出结果为undefined。

第二: 用来计数的循环变量泄露为全局变量

 // 2.用来计数的循环变量泄露为全局变量
 var arr = [1,2,3,4,5];
 for(var i = 0; i < arr.length; i++) {
     console.log(arr[i]);
 }
 console.log(i); // 5

变量 i 只用来控制循环,但是循环结束后,他并没有消失,泄露成为了全局变量。

2. 什么是块级作用域?

块级作用域由{ }包裹,例如if语句和for语句,通过let声明变量可以实现块级作用域。

例1:

 function fn() {
      let num = 10;
      if(true) {
         let num = 20;
      }
      console.log(num);
  }
  fn() // 10

if 语句的外层和内层都声明了num变量,输出的结果为10,说明if语句的块级作用域不会影响到外层作用域,如果是都用var声明则输出的结果为 20。

例2:

 var arr = [1,2,3];
 for(let i = 0; i < arr.length; i++) {
     arr[i] = function() {
         console.log(i);
     }
 }
 arr[0](); //0
 arr[1](); //1
 arr[2](); //2

 

let在代码块中都有自己的作用域,在for循环中 i 的每一个值都会单独存在一个独立的作用域,arr[i]不会被之前的arr[i]给覆盖掉。

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值