Vue3的watch函数中,第三个参数配置对象详细分析

在Vue 3的watch函数中,第三个参数是一个配置对象,用于定义如何执行watch函数。下面是几个常用的配置项的讲解,并附上代码示例:

1、immediate

immediate:当设置为true时,会在初始渲染时立即执行watch函数。默认为false

javascript 复制代码
// 示例代码
watch(
  'count',
  (newCount, oldCount) => {
    console.log(`new count: ${newCount}, old count: ${oldCount}`)
  },
  {
    immediate: true
  }
)

2、deep

deep:当设置为true时,会深度遍历监听对象的所有属性。默认为false

javascript 复制代码
// 示例代码
const state = reactive({
  obj: { a: 1, b: 2 },
  arr: [1, 2, 3]
})
watch(
  () => state.obj,
  (newObj, oldObj) => {
    console.log(`new obj: ${JSON.stringify(newObj)}, old obj: ${JSON.stringify(oldObj)}`)
  },
  {
    deep: true
  }
)

3、flush

在Vue3中,watch函数的第三个参数是可选的配置项,其中一个配置项是flush,它控制何时运行watch的回调函数。flush有三个选项:"pre""post""sync"

3.1、pre

在侦听器的回调函数运行之前立即运行更新函数,即在dom渲染完毕前调用回调函数(此时获取不到DOM!)。这是默认值。

javascript 复制代码
watch(
  () => count.value,
  () => {
    console.log("watcher callback");
  },
  { flush: "pre" }
);
3.2、post

在侦听器的回调函数运行之后立即运行更新函数,即在下一次DOM更新之后执行。

javascript 复制代码
watch(
  () => count.value,
  () => {
    console.log("watcher callback");
  },
  { flush: "post" }
);
3.3、sync

在更改被触发时立即运行侦听器的回调函数和更新函数,这是非常明确和强制的选项。

javascript 复制代码
watch(
  () => count.value,
  () => {
    console.log("watcher callback");
  },
  { flush: "sync" }
);

在大多数情况下,不需要指定flush选项,因为默认的行为通常足够了。但是,对于一些需要更精确控制的场景,flush可以是一个非常有用的配置项。

4、onTrackonTrigger

用于跟踪和调试响应式对象属性的访问和修改。onTrackonTrigger可以帮助我们更好地理解和追踪响应式数据的读取和修改操作,更好地进行调试和开发。

4.1、onTrack

onTrack选项会在我们读取响应式数据时被触发,我们可以在该函数中做一些记录或者打印日志的操作。例如:

javascript 复制代码
const state = reactive({
  count: 0,
})

watch(
  () => state.count,
  (count, prevCount) => {
    console.log(`count changed from ${prevCount} to ${count}`)
  },
  {
    onTrack: (event) => {
      console.log(`The ${event.key} key is being read`)
    },
  }
)

在这个例子中,我们在watch函数的第三个参数中配置了onTrack选项,然后在控制台输出了响应式数据读取的相关信息。

4.2、onTrigger

onTrigger选项会在响应式数据被修改时被触发,我们可以在该函数中做一些特殊的处理。例如:

javascript 复制代码
const state = reactive({
  count: 0,
})

watch(
  () => state.count,
  (count, prevCount) => {
    console.log(`count changed from ${prevCount} to ${count}`)
  },
  {
    onTrigger: (event) => {
      console.log(`The ${event.key} key is being set to ${event.value}`)
    },
  }
)

在这个例子中,我们在watch函数的第三个参数中配置了onTrigger选项,然后在控制台输出了响应式数据修改的相关信息。

5、总结

这些是`watch`函数的第三个参数的一些常见配置选项。您可以根据需要选择适当的配置来满足您的需求。

相关推荐
工业HMI实战笔记1 分钟前
图标标准化:一套可复用的工业图标库设计指南
前端·ui·性能优化·自动化·汽车·交互
2501_926978338 分钟前
分形时空理论框架:从破缺悖论到意识宇宙的物理学新范式引言(理论概念版)--AGI理论系统基础1.1
java·服务器·前端·人工智能·经验分享·agi
We་ct10 分钟前
LeetCode 146. LRU缓存:题解+代码详解
前端·算法·leetcode·链表·缓存·typescript
SuperEugene41 分钟前
数组查找与判断:find / some / every / includes 的正确用法
前端·javascript
孙笑川_43 分钟前
Vue3 源码解析系列 1:从 Debugger 视角读 Vue
前端·vue.js·源码阅读
~央千澈~1 小时前
抖音弹幕游戏开发之第11集:礼物触发功能·优雅草云桧·卓伊凡
java·前端·python
top_designer1 小时前
Magnific:老旧 UI 糊成马?720p 截图重铸 4K 界面
前端·游戏·ui·prompt·aigc·设计师·游戏策划
Cache技术分享1 小时前
326. Java Stream API - 实现自定义的 toList() 与 toSet() 收集器
前端·后端
PythonFun1 小时前
WPS动态序号填充,告别手动调整烦恼
java·前端·python
Cache技术分享1 小时前
325. Java Stream API - 理解 Collector 的三大特性:助力流处理优化
前端·后端