JS For循环内部延时执行(For循环延时)

我没猜错的话,你写的 for循环延时执行 是这样写的:

for (var i = 0; i < 6; i++) {
    setTimeout(function () {
        console.log(i);
    }, 1000)
}

是不是发现出错了啊?哈哈哈
是不是觉得应该输出0,1,2,3,4,5。但是结果却是六个6 ?

经过我一下午的琢磨和研究,找到原因,并且找到了解决办法。

原因:

js是单线程的,在执行for循环的时候,定时器被放到任务队列中等待执行,等到定时器可以执行的时候,for循环已经跑完了因此打印出六个6。

解决方法:
for (var i = 0; i < 6; i++) {
    (function (t, data) {   // 注意这里是形参
        setTimeout(function () {
            console.log(`这是第 ${t} 次,这是其他参数:${data}`);
        }, 1000 * t);	// 还是每秒执行一次,不是累加的
    })(i, '其他参数')   // 注意这里是实参,这里把要用的参数传进去
}
原理:

作用域问题
在js中,一个{}就是一个代码块,我们在for循环中定义的i变量,全局可以使用,循环中的每一次给i赋值,都是给全局变量i赋值,每次循环都会产生一个代码块,每个代码块中的都是一个新的变量

立即执行的匿名函数
给外部包装了一个立即执行的匿名函数,setTimeout里面的匿名函数不再引用外部函数的参数,而是直接引用外部匿名函数的参数,使得延迟函数的回调可以将新的作用域封闭在每次迭代的内部。

如何停止循环里面的setTimeout
var c=0;
var i=0;
var t;
var f;
function start(){
    if(c < 10){
        c++;
        i++;
        console.log(`这是第 ${i} 次,c当前值是:${c}`);
        t=setTimeout("start()",1000);
    }
}
function stop(){
    // 结束当前循环,t 是 setTimeout() 返回的值,所以会结束对应的 setTimeout()
    clearTimeout(t);
}
timedCount();

// 需要结束循环的时候,调用 stop() 函数就可以了

  • 3
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值