JS:异步输出顺序问题

闲着没事儿出一道异步的题给大伙儿打发时间

先看题目:

javascript 复制代码
<script>
2  console.log("1"); // 同步任务

4  setTimeout(() => {
5    console.log("2");
6  }, 0);
7
8  Promise.resolve().then(() => {
9    console.log("3");
10  });
11
12  (async () => {
13    console.log("4");
14
15    await new Promise((resolve) => {
16      console.log("5"); 
17      resolve(); 
18    });
19
20    console.log("6"); 
21  })();
22
23  console.log("7");
24
26</script>

解题思路:同步任务=>微任务=>下一个宏任务

再看解析:

javascript 复制代码
    <script>
      //同步任务
      console.log("1");
      //宏任务
      setTimeout(() => {
        console.log("2");
      }, 0);
      //微任务
      Promise.resolve().then(() => {
        console.log("3");
      });
      //定义一个异步函数
      (async () => {
        //同步任务
        console.log("4");
        //await new Promise会立即执行,但是会等待Promise的状态变为resolved后再执行后面的代码
        //这里依旧是同步代码的一部分
        await new Promise((resolve) => {
          //同步任务
          console.log("5");
          //romise通过resolve()变为fulfilled,await表达式就会完成,后续的任务会在微任务队列中执行
          resolve();
        });
        //微任务
        console.log("6");
      })();
      //同步任务
      console.log("7");
      //打印顺序:1 4 5 7 3 6 2
    </script>
相关推荐
安妮的小熊呢31 分钟前
CRMEB开源商城系统 & 标准版系统(PHP)开发规范
开发语言·javascript·php
BY组态37 分钟前
Ricon组态系统技术深度解析:打造高性能Web可视化平台
前端·物联网·iot·web组态·组态
山屿落星辰1 小时前
Flutter 高级特性实战:动画、自定义绘制、平台通道与 Web 优化
前端·flutter
弹简特1 小时前
【Vue3速成】01-npm+vue初体验+vite构建vue工程化
vue.js·arcgis·npm
坚定信念,勇往无前2 小时前
electron-vite 安装better-sqlite3
javascript·数据库·electron
@菜菜_达2 小时前
jquery.inputmask插件介绍
前端·javascript·jquery
QuZhengRong2 小时前
【Luck-Report】缓存
java·前端·后端·vue·excel
jiayong232 小时前
前端面试题库 - 浏览器与网络篇
前端·网络·面试
Csvn2 小时前
小程序开发:微信小程序与 uni-app 实战指南
前端
摸鱼小李上线了2 小时前
vue项目页面添加水印实现方法
前端·javascript·vue.js