前端如何创建微任务

在 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 解析来创建微任务。

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

相关推荐
exploration-earth2 分钟前
本地优先的状态管理与工具选型策略
开发语言·前端·javascript
OpenTiny社区19 分钟前
开源之夏报名倒计时3天!还有9个前端任务有余位,快来申请吧~
前端·github
ak啊24 分钟前
WebGL魔法:从立方体到逼真阴影的奇妙之旅
前端·webgl
hang_bro34 分钟前
使用js方法实现阻止按钮的默认点击事件&触发默认事件
前端·react.js·html
用户907387036486443 分钟前
pnpm是如何解决幻影依赖的?
前端
树上有只程序猿1 小时前
Claude 4提升码农生产力的5种高级方式
前端
傻球1 小时前
没想到干前端2年了还能用上高中物理运动学知识
前端·react.js·开源
咚咚咚ddd1 小时前
前端组件:pc端通用新手引导组件最佳实践(React)
前端·react.js
Lazy_zheng1 小时前
🚀 前端开发福音:用 json-server 快速搭建本地 Mock 数据服务
前端·javascript·vue.js
HJ_Coder1 小时前
基于Proxyman的实时解密和预览方案
前端