【前端每天一题】 第 5 题:Promise.then 执行顺序深入题(微任务队列机制)

事件循环第 5 题:Promise.then 执行顺序深入题(微任务队列机制)

这是事件循环中最常考、最容易写错的一题之一。

🎯 面试题:下面这段代码的执行顺序是什么?为什么?

javascript 复制代码
Promise.resolve().then(() => {
  console.log(1)
  Promise.resolve().then(() => console.log(2))
})
console.log(3)

✅ 标准答案

输出顺序:

复制代码
3
1
2

✅ 详细解析(面试官最喜欢的回答)

第一步:同步任务先执行

同步代码只有:

javascript 复制代码
console.log(3)

所以第一个输出:

复制代码
3

第二步:微任务队列分析

(1) 首先有一个微任务:
javascript 复制代码
Promise.resolve().then(() => {...})

此时微任务队列:

css 复制代码
[ taskA ]

执行 taskA(也就是外层的 then 回调):

javascript 复制代码
console.log(1)
Promise.resolve().then(() => console.log(2))

所以现在输出:

复制代码
3
1
(2) taskA 内又创建了一个新的微任务

这段代码:

javascript 复制代码
Promise.resolve().then(() => console.log(2))

把另一个微任务加入队列:

css 复制代码
[ taskB ]

事件循环会继续执行此轮的所有微任务,所以执行:

复制代码
2

最终输出:

复制代码
3
1
2

📌 关键记忆点(速记卡)

🔶 速记 1:微任务是"批处理"执行的

  • 宏任务执行完后,所有微任务会连续执行
  • 微任务内部再创建的微任务,会排到队列末尾但仍在本轮执行

🔶 速记 2:Promise.then 永远是微任务

🔶 速记 3:执行顺序优先级

顺序永远是:

  1. 同步任务
  2. 本轮所有微任务
  3. 下一轮宏任务(如 setTimeout)
相关推荐
Lzh编程小栈1 分钟前
数据结构与算法——单链表超详解(C语言完整实现 + 面试高频题)
c语言·开发语言·面试
前端摸鱼匠2 分钟前
面试题2:Transformer的Encoder、Decoder结构分别包含哪些核心组件?
人工智能·深度学习·ai·面试·职场和发展·transformer
FlyWIHTSKY5 分钟前
Vue 3 onMounted 中控制同步与异步执行策略
前端·javascript·vue.js
蜗牛攻城狮9 分钟前
【Vue3实战】El-Table实现“超过3行省略,悬停显示全文”的完美方案(附性能优化)
前端·vue.js·性能优化·element-plus
孙12~9 分钟前
前端vue3+vite,后端SpringBoot+MySQL
前端·html·学习方法
隔壁小邓11 分钟前
vue的组件化的理解之单独拆分的组件&组件的封装
前端·javascript·vue.js
困惑阿三13 分钟前
全栈部署排雷手册:从 405 报错到飞书推送成功
服务器·前端·后端·nginx·阿里云·node.js·飞书
无名-CODING14 分钟前
从零开始!Vue3+SpringBoot前后端分离项目Docker部署实战(下):Vue前端Nginx反代与致命坑点盘点
前端·spring boot·docker
我命由我1234514 分钟前
Element Plus 问题:选择框表单校验没有触发
开发语言·前端·javascript·html·ecmascript·html5·js
发际线还在16 分钟前
互联网大厂Java面试场景故事与技术解析
java·面试·技术栈·技术解析·互联网大厂·代码案例