结合microtask和macrotask理解event-loop

这篇文章真的是好文。讲的很清晰,看完之后更深一步的理解了事件循环机制。

http://www.jianshu.com/p/12b9...

简短的概述下总结

setTimeout是一个宏任务源,写在里面的回调函数会加到宏任务队列中。

Promise是一个微任务源,写在里面resolve以及reject回调会被加到微任务队列中。

事件循环可以分为这样的一个过程:分别是 宏任务->执行栈->微任务

setTimeout(function() {
    console.log('timeout1');
})

new Promise(function(resolve) {
    console.log('promise1');
    for(var i = 0; i < 1000; i++) {
        i == 99 && resolve();
    }
    console.log('promise2');
}).then(function() {
    console.log('then1');
})

console.log('global1');

比如上面这样的一段代码,setTimeout是一个宏任务源,所以里面的回调函数console.log('timeout1');会被加到宏任务队列中。到了Promise,输出promise1以及promise2,等到for循环结束后,执行resolve,由于Promise是一个微任务源,所以console.log('then1');回调会被加到微任务队列中。继续执行代码,输出grobal1。这个时候,执行栈上的代码已经执行完毕,所以此时我们执行微任务队列,此时的微任务队列上有console.log('then1');,所以浏览器输出then1。至此,一轮的事件循环已经执行完毕,开启新的一轮事件循环。也是从宏任务->执行栈->微任务。由于此时宏任务上有事件console.log('timeout1');,所以输出timeout1。这就是整段代码执行情况的理解。依次输出如下:

promise1
promise2
global1
then1
timeout1
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值