🧩面试追问:“除了 Promise,还有哪些微任务?”

面试追问:"除了 Promise,还有哪些微任务?"

本文用 3 分钟 + 3 个实战,带你吃透 queueMicrotaskMutationObserver


一、queueMicrotask:最轻量微任务

1️⃣ 语法

js 复制代码
queueMicrotask(() => {
  console.log('我在本轮微任务队列末尾执行');
});

2️⃣ 特点

  • 优先级 :高于 setTimeout、低于 Promise.then
  • 浏览器支持:Chrome 71+、Edge 79+、Safari 12.1+
  • 用途 :把非 Promise 逻辑塞进微任务队列,避免阻塞渲染

3️⃣ 实战:防抖里的微任务

js 复制代码
function microDebounce(fn) {
  let timer;
  return (...args) => {
    clearTimeout(timer);
    timer = setTimeout(() => {
      queueMicrotask(() => fn(...args));
    }, 300);
  };
}

setTimeout(...,0) 更快,0.2 ms 内执行


二、MutationObserver:DOM 变化的"间谍"

1️⃣ 语法

js 复制代码
const observer = new MutationObserver(mutations => {
  mutations.forEach(m => console.log(m));
});
observer.observe(targetNode, {
  childList: true,     // 监听子节点增删
  subtree:   true,     // 监听后代
  attributes: true,    // 监听属性变化
  attributeOldValue: true
});

2️⃣ 特点

  • 微任务执行:DOM 变更 → 微任务队列 → 回调
  • 性能友好 :批量 DOM 变化一次性处理,0 次回流

3️⃣ 实战:无限滚动加载

html 复制代码
<div id="list"></div>
<div id="sentinel">↑ 触发加载 ↑</div>
<script>
const observer = new MutationObserver(() => {
  const sentinel = document.getElementById('sentinel');
  if (sentinel && isInViewport(sentinel)) {
    loadMore();
  }
});
observer.observe(document.body, { childList: true, subtree: true });
</script>

4️⃣ 实战:自动保存编辑器内容

js 复制代码
const editor = document.querySelector('#editor');
const observer = new MutationObserver(() => {
  localStorage.setItem('draft', editor.innerHTML);
});
observer.observe(editor, { childList: true, subtree: true });

三、组合连招:微任务里监听 DOM

js 复制代码
queueMicrotask(() => {
  new MutationObserver(() => {
    console.log('DOM changed in microtask');
  }).observe(document, { childList: true });
});

执行顺序:DOM 变更 → MutationObserver → queueMicrotask → Promise.then → 渲染


四、一句话总结

  • queueMicrotask :把任何逻辑塞进微任务队列末尾------快、轻、无 UI 阻塞
  • MutationObserver :DOM 变化后微任务触发------批量、0 回流、性能王者
相关推荐
多多*9 分钟前
2026年最新 测试开发工程师相关 Linux相关知识点
java·开发语言·javascript·算法·spring·java-ee·maven
Laurence11 分钟前
从零到一构建 C++ 项目(IDE / 命令行双轨实现)
前端·c++·ide
会编程的土豆18 分钟前
简易植物大战僵尸游戏 JavaScript版之html
javascript·游戏·html
雯0609~20 分钟前
hiprint-官网vue完整版本+实现客户端配置+可实现直接打印(在html版本增加了条形码、二维码拖拽等)
前端·javascript·vue.js
VT.馒头21 分钟前
【力扣】2705. 精简对象
javascript·数据结构·算法·leetcode·职场和发展·typescript
GISer_Jing23 分钟前
构建高性能Markdown引擎开发计划
前端·aigc·ai编程
摘星编程27 分钟前
在OpenHarmony上用React Native:Switch禁用状态
javascript·react native·react.js
CHU72903541 分钟前
生鲜商城小程序前端功能版块:适配生鲜采购核心需求
前端·小程序
huangyiyi666661 小时前
Vue + TS 项目文件结构
前端·javascript·vue.js
0思必得01 小时前
[Web自动化] Selenium处理Cookie
前端·爬虫·python·selenium·自动化