js异步之微任务与宏任务

本文详细解释了JavaScript中的微任务(如Promise回调和MutationObserver)和宏任务(如setTimeout和DOM事件)的概念,阐述了它们的执行顺序以及在Web开发中的重要性,确保异步操作的正确性和性能提升。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

1.js中什么是微任务和宏任务

在 JavaScript 引擎中,任务分为两种类型:微任务(microtask)和宏任务(macrotask)。 
微任务是指在当前任务执行结束后立即执行的任务,它可以看作是在当前任务的“尾巴”添加的任务。
常见的微任务包括 Promise 回调和 process.nextTick。 
宏任务是指需要排队等待 JavaScript 引擎空闲时才能执行的任务。
常见的宏任务包括 setTimeout、setInterval、I/O 操作、DOM 事件等。
JavaScript 引擎会先执行当前任务中的所有微任务,然后再执行宏任务队列中的第一个任务。
这个过程会不断重复,直到宏任务队列中的任务被全部执行完毕。

2.JS区分微任务和宏任务的意义

JavaScript 之所以要区分微任务和宏任务,是因为微任务和宏任务的执行顺序不同,这对 Web 开发中一些异步操作的实现有着重要的影响。 
在 JavaScript 中,微任务会优先于宏任务执行。
这意味着在当前任务执行结束后,所有微任务都会被立即执行,而宏任务只有在所有微任务执行完毕后才会执行。
这种执行顺序保证了微任务的优先级,可以避免一些问题的出现,比如处理 Promise 对象时可能会出现的竞态条件。 
举个例子,当我们使用 Promise 对象时,它会返回一个 Promise 实例并将回调函数放入微任务队列中。当 Promise 的状态发生改变时,它会立即执行微任务队列中的回调函数,而不是等待当前任务结束后再执行。
这种特性可以保证 Promise 回调函数的执行顺序,避免出现竞态条件,从而使代码更加可靠。 
另一方面,宏任务的执行是在当前任务结束后才会执行的,这意味着可以将一些耗时的操作放入宏任务队列中,从而避免阻塞当前任务的执行。
比如,我们可以将一些需要等待一段时间才能执行的代码放入 setTimeout 的回调函数中,这样可以使页面在执行这些代码的同时仍然保持响应,提高用户体验。 
因此,JavaScript 之所以要区分微任务和宏任务,是为了保证异步操作的正确性和性能。

3.JS中微任务和宏任务执行顺序

首先执行当前代码(同步任务),直到遇到第一个宏任务或微任务。
如果遇到微任务,则将它添加到微任务队列中,继续执行同步任务。
如果遇到宏任务,则将它添加到宏任务队列中,继续执行同步任务。
当前任务执行完毕后,JavaScript 引擎会先执行所有微任务队列中的任务,直到微任务队列为空。
然后执行宏任务队列中的第一个任务,直到宏任务队列为空。
重复步骤 4 和步骤 5,直到所有任务都被执行完毕。

4.js微任务和宏任务有哪些

微任务:Promise 回调函数、process.nextTick、Object.observe(已废弃)、MutationObserver。
宏任务:setTimeout、setInterval、setImmediate(Node.js 独有)、requestAnimationFrame、I/O 操作、UI 渲染。

5.js微任务和宏任务执行顺序代码

 async function async1() {
            console.log('async1 start'); //2
            await async2();
            console.log('async1 end'); //6
        }

        async function async2() {
            console.log('async2'); //3
        }

        console.log('script start'); //1

        setTimeout(function () {
            console.log('setTimeout'); //8
        }, 0)

        async1();

        new Promise(function (resolve) {
            console.log('promise1'); //4
            resolve();
        }).then(function () {
            console.log('promise2'); //7
        });
        console.log('script end'); //5
        //输出:
        //script start
        //async1 start
        //async2
        //promise1
        //script end
        //async1 end
        //promise2
        //setTimeout

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值