js实现异步循环实现代码

前端之家收集整理的这篇文章主要介绍了js实现异步循环实现代码前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。

问题

实现异步循环时,你可能会遇到问题。

让我们试着写一个异步方法,一次循环打印一次循环的索引值。

for(var i = 0; i < 5; i++){ setTimeout(function(){ document.writeln(i);document.writeln("
"); },1000); }

如上程序的输出为:

5 5 5 5 5

原因

每次时间结束(timeout)都指向原始的i,而并非它的拷贝。所以,for循环使i增长到5,之后timeout运行并调用了当前i的值(也就是5)。

解决方法

有几个不同的方式可以拷贝i。最普通且常用方法是通过声明函数来建立一个闭包,并将i传给此函数。我们这里使用了自调用函数

运行代码

for(var i = 0; i < 5; i++){ (function(num){ setTimeout(function(){ document.writeln(num);document.writeln("
"); },1000); })(i); }

输出

0 1 2 3 4

猜你在找的JavaScript相关文章