【前端每天一题】🔥 第 14 题:Promise.then 链式调用执行顺序

这道题是大厂面试常考题,核心考察对事件循环和微任务队列的理解。


✅ 第 14 题:Promise.then 链式调用执行顺序


📘 一、核心概念

  • Promise.then / catch / finally 回调都是微任务(microtask)
  • 微任务队列:当前宏任务执行完后立即执行所有微任务
  • 同步代码先执行 → 微任务 → 宏任务

📘 二、经典题目

javascript 复制代码
console.log('script start');

setTimeout(() => {
  console.log('setTimeout');
}, 0);

Promise.resolve().then(() => {
  console.log('promise1');
}).then(() => {
  console.log('promise2');
});

console.log('script end');

📘 三、详细分析(步步解析)

  1. 同步执行
arduino 复制代码
console.log('script start') // 输出 1
console.log('script end')   // 输出 2
  1. 微任务队列(Promise.then)
  • 第一个 then 回调 → 输出 'promise1'
  • 第二个 then 回调 → 输出 'promise2'
  1. 宏任务队列(setTimeout)
  • 输出 'setTimeout'

📘 四、最终输出顺序

arduino 复制代码
script start
script end
promise1
promise2
setTimeout

✅ 面试官非常喜欢问这个输出顺序。


📘 五、速记卡(10 秒复盘版)

javascript 复制代码
🎯 同步代码 > 微任务(Promise.then) > 宏任务(setTimeout/setInterval/IO)

🎯 Promise.then 内再 then → 链式微任务,依次执行

🎯 核心点:
- Promise.then 回调总是微任务
- 微任务会在当前宏任务结束后立即执行
- 微任务内部再生成微任务,会追加到队列末尾

📘 六、拓展题(加分)

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

输出顺序:

复制代码
1
3
2

解释:

  • '1' → 微任务队列第一个
  • setTimeout → 宏任务
  • 第二个 then → 微任务队列末尾,紧跟 '1' 执行
  • 宏任务最后执行 '2'

相关推荐
奇奇怪怪的11 分钟前
Embedding 模型 10+ 横向评测
前端
陈广亮14 分钟前
Monorepo 从 0 到 1 实操指南 2026 版:pnpm catalogs + Turborepo 2.x + changesets 全链路
前端
子兮曰15 分钟前
OpenMontage 深度解剖:你的 AI 编程助手,其实是个视频工作室
前端·后端·ai编程
敲代码的鱼16 分钟前
PDF 预览与签名批注写回 支持安卓 iOS 鸿蒙 UTS插件
android·前端·ios
子兮曰23 分钟前
前端工具链的「Rust 化」:一场没有赢家的军备竞赛?
前端·后端·rust
Hyyy1 小时前
Function Calling / Tool Use的原理和实现模式
前端·llm·ai编程
爱勇宝2 小时前
从 Ctrl+CV 到 Enter:程序员正在失去什么
前端·后端·程序员
洛卡卡了2 小时前
我们在用 AI 写代码时,为什么建议要好好维护 AGENTS.md 呢?
面试·agent·claude
徐小夕2 小时前
我们开源了一款“框架无关”的思维导图编辑器,3分钟集成到任意系统
前端·javascript·github
PBitW2 小时前
GPT训练我的第三天,明白了应该咋说满分回答!😕😕😕
前端·javascript·面试