async和await的事件循环机制示例

示例一、

html 复制代码
<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
</head>

<body>
    <script>
        // 宏任务:setTimeout

        // 微任务:ansync2已完成,7

        async function async1() {
            console.log(1) // 第二个打印
            // 这一步是非常重要的
            await async2() // "ansync2已完成"这一步微任务执行完后就把下面的送进微任务队列中
            console.log(2) // 这个时候的微任务队列就是7,2了,依次执行,最后执行宏任务:setTimeout
        }

        async function async2() {
            await console.log(3)
            // 第三个打印,这个时候的async2已经完成,把"ansync2已完成"放进微任务
            // 然后先别管,先去执行同步任务
        }

        console.log(4) // 第一个打印

        setTimeout(function () {
            console.log(5) // 进宏任务里了哈
        }, 0)

        async1();

        new Promise(function (resolve) {
            console.log(6) // 第四个打印
            resolve();
        }).then(function () {
            console.log(7) // 进微任务里面
        })

        console.log(8) // 第五个打印,到这里的时候同步代码就已经执行完了,现在回去看看微任务队列

        // 现在的微任务队列是这样的:ansync2已完成,7;那就执行"ansync2已完成"这一步。

        // 打印顺序答案:4,1,3,6,8,7,2,5
    </script>
</body>

</html>

示例二、

html 复制代码
<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
</head>

<body>
    <script>
        // 宏任务:setTimeout

        // 微任务:4,6,8,asy2已完成,2

        async function asy1() {
            console.log(1); // 第一个打印
            await asy2(); // asy2还没完成,所以先去完成同步代码
            console.log(2); // asy2完成后把这个推进微队列中 第七个打印
        }

        asy2 = async () => {
            await (async () => {
                await (() => {
                    console.log(3); // 第二个打印
                })(); // 这里也是立即执行
                console.log(4); // 上面的await完成后就把这个送进了微任务 第四个打印
            })(); // 这里立即执行
            console.log(8); // 放进微任务 第六个打印
        };

        asy3 = async () => {
            Promise.resolve().then(() => {
                console.log(6); // 第五个打印
            })
        }

        asy1()

        console.log(7); // 第三个打印

        asy3()

        // 打印顺序答案:1,3,7,4,6,8,2
    </script>
</body>

</html>
相关推荐
酒尘&31 分钟前
JS数组不止Array!索引集合类全面解析
开发语言·前端·javascript·学习·js
学历真的很重要1 小时前
VsCode+Roo Code+Gemini 2.5 Pro+Gemini Balance AI辅助编程环境搭建(理论上通过多个Api Key负载均衡达到无限免费Gemini 2.5 Pro)
前端·人工智能·vscode·后端·语言模型·负载均衡·ai编程
用户47949283569152 小时前
"讲讲原型链" —— 面试官最爱问的 JavaScript 基础
前端·javascript·面试
用户47949283569152 小时前
2025 年 TC39 都在忙什么?Import Bytes、Iterator Chunking 来了
前端·javascript·面试
JIngJaneIL2 小时前
基于Java非遗传承文化管理系统(源码+数据库+文档)
java·开发语言·数据库·vue.js·spring boot
+VX:Fegn08952 小时前
计算机毕业设计|基于springboot + vue心理健康管理系统(源码+数据库+文档)
数据库·vue.js·spring boot·后端·课程设计
大怪v3 小时前
【Virtual World 04】我们的目标,无限宇宙!!
前端·javascript·代码规范
狂炫冰美式3 小时前
不谈技术,搞点文化 🧀 —— 从复活一句明代残诗破局产品迭代
前端·人工智能·后端
xw54 小时前
npm几个实用命令
前端·npm
!win !4 小时前
npm几个实用命令
前端·npm