两段代码结果与作用域关系

for (var i = 0; i < 10; i++) {
    setTimeout(function() { console.log(i); }, 100 * i);
}

结果:

10
10
10
10
10
10
10
10
10
10

2.

for (var i = 0; i < 10; i++) {
    (function(i) {
        setTimeout(function() { console.log(i); }, 100 * i);
    })(i);
}

结果:

0
1
2
3
4
5
6
7
8
9

我们传给setTimeout的每一个函数表达式实际上都引用了相同作用域里的同一个i

 setTimeout在若干毫秒后执行一个函数,并且是在for循环结束后。 for循环结束后,i的值为10。 所以当函数被调用的时候,它会打印出 10

一个通常的解决方法是使用立即执行的函数表达式(IIFE)来捕获每次迭代时i的值。

 参数 i会覆盖for循环里的i,但是因为我们起了同样的名字,所以我们不用怎么改for循环体里的代码。

猜你喜欢

转载自blog.csdn.net/weixin_42659625/article/details/81229443