var在for循环中出现问题的原因以及var和let的区别

        var arr = []
        for (var i = 0; i < 5; i++) {
            arr[i] = function() {
                console.log(i);
            }
        }
        arr[0]() //5
        arr[2]() //5
        console.log(arr[1]);
        for (var j = 0; j < 5; j++) {
            setTimeout(() => {
                console.log(j);
            }, 0);
        }
        //输出 5 5 5 5 5 

        由于循环内部是异步代码会在for循环结束后才会执行,而var关键字没有块级作用域,只有函数作用域,每一个i都会被下一个i的值所覆盖,当异步代码执行时会沿着作用域链向上查找i的值,由于i最后的值为5,所以每次执行的结果都为5

    for (let i = 0; i < 5; i++) {
            setTimeout(() => {
                console.log(i);
            }, 0);
        }
//输出 1 1 1 1 1

       而let关键字的作用域是块级作用域,在每次循环中都会产生一个新的块,每个块都是独立的作用域,不会互相影响,而每个块中i的值为当前循环i的值。 最后执行的异步代码会在自己的块级作用域中找到i值。

      var和let的区别

         1.var可以被重复定义,let不可以(条件声明)

         2.var会声明提升,let不会(暂时性死区)

         3.var声明的全局变量会成为window身上的一个属性而let不会

         4.var为函数作用域,let为块级作用域

 

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值