【前端每天一题】🔥 第 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'

相关推荐
一 乐4 小时前
婚纱摄影网站|基于ssm + vue婚纱摄影网站系统(源码+数据库+文档)
前端·javascript·数据库·vue.js·spring boot·后端
C_心欲无痕5 小时前
ts - tsconfig.json配置讲解
linux·前端·ubuntu·typescript·json
清沫5 小时前
Claude Skills:Agent 能力扩展的新范式
前端·ai编程
yinuo5 小时前
前端跨页面通信终极指南:方案拆解、对比分析
前端
yinuo6 小时前
前端跨页面通讯终极指南⑨:IndexedDB 用法全解析
前端
xkxnq6 小时前
第二阶段:Vue 组件化开发(第 16天)
前端·javascript·vue.js
烛阴6 小时前
拒绝配置地狱!5 分钟搭建 Three.js + Parcel 完美开发环境
前端·webgl·three.js
xkxnq7 小时前
第一阶段:Vue 基础入门(第 15天)
前端·javascript·vue.js
辞砚技术录8 小时前
MySQL面试题——联合索引
数据库·面试
anyup8 小时前
2026第一站:分享我在高德大赛现场学到的技术、产品与心得
前端·架构·harmonyos