前端如何创建微任务

在 JavaScript 中,微任务(microtask)是在当前同步代码执行完毕后立即执行的任务,并且在下一个宏任务开始之前。它们确保了某些操作能够在当前任务完成后尽快得到处理。以下是一些可以创建微任务的对象和方法:

1. Promise

Promise 是创建微任务最常见的方式之一。当一个 Promise 被解析或拒绝时,它的 .then().catch().finally() 回调会被添加到微任务队列中。

javascript 复制代码
console.log('Start');

Promise.resolve().then(() => console.log('Microtask from Promise'));

console.log('End');


// 输出顺序
// Start
// End
// Microtask from Promise

2. MutationObserver

MutationObserver 用于监视 DOM 树的变化。当观察到的变化被提交时,MutationObserver 的回调函数会被添加到微任务队列中。

javascript 复制代码
console.log('Start');

const observer = new MutationObserver(() => {
  console.log('Microtask from MutationObserver');
});

observer.observe(document.body, { childList: true });

document.body.appendChild(document.createElement('div'));

console.log('End');

// 输入顺序
// Start
// End
// Microtask from MutationObserver

3. queueMicrotask()

queueMicrotask() 是一个专门用于将回调函数添加到微任务队列的函数。它接受一个回调函数作为参数,并确保该回调会在当前同步代码执行完毕后立即执行。

javascript 复制代码
onsole.log('Start');

queueMicrotask(() => console.log('Microtask from queueMicrotask'));

console.log('End');

// 输出顺序
// Start
// End
// Microtask from queueMicrotask

queueMicrotask 浏览器兼容性:

4. process.nextTick(Node.js 环境)

在 Node.js 环境中,process.nextTick() 也可以用来创建微任务。它会将回调函数添加到微任务队列中,确保其在当前操作完成之后但在事件循环进入下一轮之前执行。

示例(仅适用于 Node.js)
javascript 复制代码
console.log('Start');

process.nextTick(() => console.log('Microtask from process.nextTick'));

console.log('End');

// 输出顺序
// tart
// End
// Microtask from process.nextTick

5. async/await

虽然 async/await 不是直接创建微任务的方法,但当你使用 await 等待一个 Promise 解析时,await 后面的代码会被作为一个微任务添加到微任务队列中。

javascript 复制代码
console.log('Start');

(async function() {
  await Promise.resolve();
  console.log('Microtask from async/await');
})();

console.log('End');

// 输出顺序
// Start
// End
// Microtask from async/await

总结

以下是可以在 JavaScript 中创建微任务的主要方式:

  • Promise :通过 .then().catch().finally() 方法。
  • MutationObserver:监视 DOM 变化并触发微任务。
  • queueMicrotask():专门用于将回调添加到微任务队列的函数。
  • process.nextTick:仅适用于 Node.js 环境。
  • async/await:通过等待 Promise 解析来创建微任务。

这些方法允许你在不同的场景中灵活地控制异步操作的执行时机,确保某些代码能够在当前任务完成后尽快执行。如果你有更多具体的问题或需要进一步的帮助,请随时提问!

相关推荐
莫的感情10 分钟前
下载按钮点击一次却下载两个文件问题
前端
一个很帅的帅哥14 分钟前
JavaScript事件循环
开发语言·前端·javascript
小宁爱Python19 分钟前
Django Web 开发系列(二):视图进阶、快捷函数与请求响应处理
前端·django·sqlite
fox_19 分钟前
深入理解React中的不可变性:原理、价值与实践
前端·react.js
Github项目推荐21 分钟前
你的错误处理一团糟-是时候修复它了-🛠️
前端·后端
Code小翊26 分钟前
C语言bsearch的使用
java·c语言·前端
云枫晖27 分钟前
Webapck系列-初识Webpack
前端·javascript
慧一居士30 分钟前
HTML5 功能介绍,使用场景,对应功能点完整使用示例
前端
海在掘金6112738 分钟前
告别“undefined is not a function”:TS如何让你的函数调用更安心
前端
云中雾丽41 分钟前
Flutter中Stream的各种使用场景和实现方式
前端