for循环中加入异步代码输出案例

问题:

for(var i=0; i < 10; i++) {                
    setTimeout(function() {
    console.log(i);
    }, 1000);
} //输出10个10

原因:setTimeout是异步的,只有主线程上的程序执行结束,才会执行异步函数。在该for循环中,循环10次,就会在队列中加入10个setTimeout,等for循环结束了,才会执行那10个setTimeout。for循环结束时,i=10,因此会输出10个10。

如果想要正常输出0~9

//1、利用块级作用域
for(let i=0; i < 10; i++) {                
 setTimeout(function() {
 console.log(i);
 }, 1000);
} 

//2、利用自执行函数,将i作为参数传入
for(var i=0; i < 10; i++) {
 (function(i) {
     setTimeout(function() {
         console.log(i);
 }, 1000);
 })(i);        
}

//3、利用setTimeout的第三个参数,将i作为参数传入function
for(var i=0; i < 10; i++) {
 setTimeout(function(j) {
 console.log(j);
 }, 1000, i);
}

//4、利用promise
for(var i=0; i < 10; i++) {
 new Promise((resolve, reject) => {
 var j = i;
 setTimeout(function() {
     console.log(j)
 }, 1000);
 })
}

//5、利用async函数
async function foo() {
 for(var i=0; i < 10; i++) {
 let result = await new Promise((resolve, reject) => {
     setTimeout(function() {
     resolve(i);
         }, 1000);
 });
 console.log(result);
 }
}
foo(); 
  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值