闭包与自执行函数

1、for循环与setTimeout

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

输出结果:3 3 3

2、将延迟时间换成0

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

 输出结果:3 3 3

这是什么原因?

JavaScript是单线程执行的,无法同时执行多段代码。当某段代码正在执行时,后续任务都必须等待,形成一个队列。只有当前任务执行完毕,才会从队列中取出下一个任务——也就是常说的“阻塞式执行”。

通俗点说,js由上至下执行,遇到settimeout就先挂起,继续向下执行,全部执行完毕后,再执行settimeout,所以输出结果还是3,3,3。

如果想要输出0, 1,2呢?

3、

for( var i=0;i<3;i++){
    (function(i){
        setTimeout(function(){
            console.log(i);
        },300);
    })(i);
}
// 或者
for( var i=0;i<3;i++){
    setTimeout((function(i){
        console.log(i);
    })(i)
    ,300);
}

输出结果:0,1,2

4、有兴趣可以查一下setimeout(0)的作用

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值