BruceGwo 2023-10-31 11:03 采纳率: 100%
浏览 3
已结题

在一下promise与setTimeout输出顺序以及原因


console.log('script start');  // 宏任务

setTimeout(function() {
  console.log('setTimeout');  // 宏任务
}, 0);

Promise.resolve().then(function() {
  console.log('promise1');    // 微任务
}).then(function() {
  console.log('promise2');    // 微任务
});

console.log('script end');    // 宏任务

请问输出顺序及原因,谢谢

  • 写回答

2条回答 默认 最新

  • 前端不释卷leo 前端领域新星创作者 2023-10-31 11:52
    关注

    script start
    script end
    promise1
    promise2
    setTimeout

    Promise.resolve() 实际上返回一个Promise实例(new Promise)

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(1条)

报告相同问题?

问题事件

  • 系统已结题 11月8日
  • 已采纳回答 10月31日
  • 创建了问题 10月31日