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 更新后才执行,避免不必要的更新操作。

👉点击进入 我的网站

相关推荐
徐小夕@趣谈前端5 分钟前
Web文档的“Office时刻“:jitword共建版2.0发布!让浏览器变成本地生产力
前端·数据结构·vue.js·算法·开源·编辑器·es6
Data_Journal18 分钟前
如何使用 Python 解析 JSON 数据
大数据·开发语言·前端·数据库·人工智能·php
德育处主任Pro18 分钟前
纯前端网格路径规划:PathFinding.js的使用方法
开发语言·前端·javascript
墨笔.丹青24 分钟前
基于QtQuick开发界面设计出简易的HarmonyUI界面----下
开发语言·前端·javascript
董世昌4141 分钟前
深度解析浅拷贝与深拷贝:底层逻辑、实现方式及实战避坑
前端·javascript·vue.js
扶苏10021 小时前
vue使用event.dataTransfer实现A容器数据拖拽复制到到B容器
前端·vue.js·chrome
David凉宸1 小时前
Vue 3 项目的性能优化策略:从原理到实践
前端·vue.js·性能优化
小马_xiaoen1 小时前
Proxy 与 Reflect 从入门到实战:ES6 元编程核心特性详解
前端·javascript·ecmascript·es6
hoiii1871 小时前
MATLAB SGM(半全局匹配)算法实现
前端·算法·matlab
计算机学姐2 小时前
基于SpringBoot的民宿预定管理系统【三角色+个性化推荐算法+数据可视化统计】
java·vue.js·spring boot·mysql·信息可视化·intellij-idea·推荐算法