【前端每天一题】 第 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)
相关推荐
用户57573033462417 小时前
从 LocalStorage 待办清单到 CSS 核心机制:一次搞懂数据持久化、继承与盒模型陷阱
前端
codingWhat17 小时前
前端组件库开发实践:从零到发布
前端·npm·vite
cxxcode17 小时前
浏览器模块加载与 Webpack 打包原理
前端
兆子龙17 小时前
React Compiler 来了:少写 useMemo,照样稳
前端·架构
用户54330814419417 小时前
Manifest V3 实战:从补天网站逆向到 Chrome 扩展开发全记录
前端·后端
zhqiok17 小时前
React中类似于Vue中Pinia的轻量级状态管理神器——Zustand
前端
Mintopia17 小时前
促成高端技术方案形成的关键要素与实践路径
前端
摸鱼的春哥19 小时前
春哥的Agent通关秘籍13:实现RAG查询
前端·javascript·后端
明月_清风19 小时前
滚动锁定:用户向上翻看历史时,如何阻止 AI 新消息把它“顶”下去?
前端·javascript
明月_清风19 小时前
当高阶函数遇到 AI:如何自动化生成业务层面的逻辑拦截器
前端·javascript·函数式编程