await/promise 宏任务 微任务 执行顺序

1eventloop

js是单线程,故同时只能执行一个任务,eventloop是保证执行事件不阻塞的一个事件执行机制。

js中分为同步任务和异步任务。异步任务又分为宏任务微任务

js主线程在执行代码时,首先执行同步任务,然后执行异步任务。在按照代码顺序执行时,主线程执行同步代码,遇到异步代码,判断宏任务还是微任务,将其注册事件,分别加入宏任务队列和微任务队列,同步代码执行完毕后,判断微任务队列是否有事件,若有,将微任务队列所有事件执行完毕,在按照先进先出的顺序执行的一个宏任务事件。

await 会让出线程,阻塞后面的代码执行,跳出执行外部的同步代码,执行完毕,会返回执行被阻塞的代码。

2.事件分类

宏任务:setTimeout/setInterval/ requestAnimationFrame的回调函数

微任务:promise.then()/process.nexttick中的回调函数

同步代码:console.log/settimeout/new promise()等

3执行顺序

执行顺序,先宏任务再微任务ÿ

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 2
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值