查看: 99|回复: 0

vue3中的watchPostEffect在DOM 更新后的副作用处理方案

[复制链接]

0

主题

0

回帖

0

积分

积极分子

金币
0
阅读权限
220
精华
0
威望
0
贡献
0
在线时间
0 小时
注册时间
2012-4-1
发表于 2025-12-31 11:57:14 | 显示全部楼层 |阅读模式

watchPostEffectDOM 更新完成后watchEffect

1.watchPostEffect的基本用法

<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.watchPostEffect与watchEffect的对比

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

3. 使用场景

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

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

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

相关侵权、举报、投诉及建议等,请发 E-mail:qiongdian@foxmail.com

Powered by Discuz! X5.0 © 2001-2026 Discuz! Team.

在本版发帖返回顶部