您的位置:首页 > Web前端 > JavaScript

Js 闭包传参 setInterval 多次

2016-11-16 16:48 239 查看
A friend 问了我一个问题,大概是在一个for循环中启动多个定时器。

代码大概如下,

var list = [1, 2, 3, 4, 5];

for (var x in list) {
setInterval(function() {
// list[x] += 10;
console.log(x + "=>" + list[x] + "\n");
}, 2 * 1000);
}


结果是每两秒钟打印五次,打印的全都一样都是 4=>5

执行结果



不论怎么样都是缺点东西,x相对于5 个setInterval 实例,都是共有变量,缺个每个setInterval自己变量。我也没见过别的用法,想到了函数闭包传参,没见过。Google Stackoverflow

var list = [1, 2, 3, 4, 5];

for (var x in list) {
setInterval(function(i) {
// list[x] += 10;
console.log(x + "=>" + list[i] + "\n");
}, 2 * 1000, x);
}


执行结果



Reference

how-to-use-setinterval-function-within-for-loop (stackoverflow)
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息