vue3 - watchPostEffect在DOM 更新后的副作用处理

文章目录

    • [1. `watchPostEffect` 的基本用法](#1. watchPostEffect 的基本用法)
    • [2. `watchPostEffect` 与 `watchEffect` 的对比](#2. watchPostEffectwatchEffect 的对比)
    • [3. 使用场景](#3. 使用场景)

watchPostEffect 用于在 DOM 更新完成后 执行回调。这是 Vue 响应式系统中一个相对较新的 API,允许你执行那些需要在 Vue 完成更新后进行的任务,例如 DOM 操作、第三方库更新等。它的行为与 watchEffect 类似,但执行时机更加延迟,确保所有 DOM 更新都已完成。

1. watchPostEffect 的基本用法

js 复制代码
<template>
  <div>
    <h1>{{ count }}</h1>
    <button @click="updateCount">修改 count</button> <br />
  </div>
</template>
<script setup lang="ts">
import { ref, watchPostEffect, watchEffect } from "vue";

const count = ref(0);

// 执行比watchPostEffect要早,因为它是在 DOM 更新之前执行的
watchEffect(() => {
  console.log(`watchEffect - ${count.value}`);
});

// 执行比watchEffect要晚,因为它是在 DOM 更新之后执行的
watchPostEffect(() => {
  console.log(`watchPostEffect - DOM 已更新,当前 count 值为: ${count.value}`);
});
function updateCount() {
  count.value++; // 数据变化,视图更新后,watchPostEffect 执行
}
</script>

在这个例子中:

  • watchPostEffect 会在 count 改变之后,视图更新完成后执行回调,打印出最新的 count 值。执行时机始终是比 watchEffect 要晚的。

如图所示:

2. watchPostEffectwatchEffect 的对比

特性 watchEffect watchPostEffect
执行时机 在响应式数据变化后,立即执行回调函数 在响应式数据变化后,DOM 更新完成后执行回调
适用场景 当你希望在数据变化后立刻执行副作用 当你希望在 DOM 更新后执行副作用,如操作 DOM 或调用第三方库
常见用途 计算值、触发数据相关的副作用 DOM 操作、与非 Vue 的库交互、做布局等操作

3. 使用场景

watchPostEffect 主要用于那些需要在 DOM 更新之后 执行的副作用操作。这包括但不限于:

  • DOM 操作:例如,调整元素的位置、大小、或者在更新后执行的动画。
  • 第三方库:如果你在 Vue 中使用了第三方库(例如图表库、地图插件等),而这些库需要等到 Vue 完成 DOM 更新后再进行渲染或者更新。
  • 性能优化:确保某些操作仅在 DOM 更新后才执行,避免不必要的更新操作。

👉点击进入 我的网站

相关推荐
donecoding1 小时前
一个 sudo 引发的血案:npm 全局包权限错乱彻底修复
前端·node.js·前端工程化
风骏时光牛马1 小时前
Raku正则匹配与数据批量处理实操案例
前端
nbwenren1 小时前
2026实测:Gemini 3 镜像站视觉能力实践——拍照原型图,一键生成 HTML+CSS 代码
前端·css·html
Lee川1 小时前
Prisma 实战指南:像搭积木一样设计古诗词数据库
前端·数据库·后端
jinanwuhuaguo1 小时前
(第二十九篇)OpenClaw 实时与具身的跃迁——从异步孤岛到数字世界的“原住民”
前端·网络·人工智能·重构·openclaw
广州华水科技1 小时前
深度测评2026年单北斗GNSS位移监测系统推荐,与高口碑变形监测设备一同引领行业新风尚
前端
Alice-YUE2 小时前
【js高频八股】防抖与节流
开发语言·前端·javascript·笔记·学习·ecmascript
是上好佳佳佳呀3 小时前
【前端(十一)】JavaScript 语法基础笔记(多语言对比)
前端·javascript·笔记
CDN3604 小时前
排查实录:网站偶发502/504错误?360CDN回源超时配置与日志分析技巧
前端·数据库