当前位置: 首页 > article >正文

前端如何创建微任务

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

1. Promise

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

console.log('Start');

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

console.log('End');


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

2. MutationObserver

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

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

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)
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 后面的代码会被作为一个微任务添加到微任务队列中。

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

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


http://www.kler.cn/a/506685.html

相关文章:

  • 【Qt】03-页面切换
  • 归纳webpack
  • 微信小程序校园自助点餐系统实战:从设计到实现
  • 【GIS操作】使用ArcGIS Pro进行海图的地理配准(附:墨卡托投影对比解析)
  • 【Vim Masterclass 笔记14】S07L29 + L30:练习课08 —— Vim 文本对象同步练习(含点评课内容)
  • 大疆上云API基于源码部署
  • 【gRPC】clientPool 客户端连接池简单实现与go案例
  • Go语言之路————条件控制:if、for、switch
  • Oracle EBS GL定期盘存WIP日记账无法过账数据修复
  • Go语言封装加解密包(AES/DES/RSA)
  • Sprint Boot教程之五十八:动态启动/停止 Kafka 监听器
  • 说说Babylon.js中scene.deltaTime的大坑
  • 如何异地远程访问本地部署的Web-Check实现团队远程检测与维护本地站点
  • 《DeepSeek V3:重新定义AI大模型的效率与成本》
  • Qt实现防止程序多次运行
  • Java学习教程,从入门到精通,JDBC数据库连接语法知识点及案例代码(92)
  • Outlook 无网络连接[2604] 错误解决办法
  • python批量doc转pdf调用提示库未注册
  • 华北水利水电大学第十届ACM/ICPC程序设计新生赛题解
  • Django Admin 实战:实现 ECS 集群批量同步功能
  • 【6】Word:海名公司文秘❗
  • SuperMap iClient3D for Cesium立体地图选中+下钻特效
  • 【Docker】使用Dev Container进行开发
  • HTML 中的 Window 和 Document 介绍
  • 【Uniapp-Vue3】manifest.json配置
  • 前后端分离开发心得