Vue 3 中 watch 的报错解析

🚀 Vue 3 中 watch 的报错解析:一篇搞懂! 🚀

在 Vue 3 中使用 watch 时,你可能会遇到这样的报错:

python 复制代码
No overload matches this call.
  The last overload gave the following error.
    Argument of type 'number | undefined' is not assignable to parameter of type 'object'.
      Type 'undefined' is not assignable to type 'object'.

今天我们就来彻底搞懂这个报错的原因,以及如何正确使用 watch!👇


1. 报错原因分析

这个报错的核心问题是:watch的第一个参数类型不匹配。

1.1 代码片段

javascript 复制代码
const props = defineProps({
  code: {
    type: Number,
    required: false,
  },
});

watch(props.code, (newValue, oldValue) => {
  // 回调函数
});

1.2 问题出在哪里?

  • props.code 的类型是 number | undefined(因为 required: false)。
  • watch 的第一个参数期望是一个 响应式对象getter 函数,而不是一个具体的值。

2. 为什么watch(() => props.code) 不会报错?

当你使用 () => props.code 时,watch 的第一个参数是一个 getter 函数 ,它会返回 props.code 的值。

  • getter 函数的作用
    • 返回一个响应式值。
    • watch 可以监听这个 getter 函数返回的值的变化。

2.1 正确写法

javascript 复制代码
watch(() => props.code, (newValue, oldValue) => {
  // 回调函数
});

2.2 为什么这样写不会报错?

  • () => props.code 是一个函数,返回 props.code 的值。
  • watch 可以正确监听 props.code 的变化。

3. watch 的正确用法

在 Vue 3 中,watch 的用法有以下几种:

3.1 监听响应式对象

ini 复制代码
const state = reactive({ count: 0 });

watch(state, (newValue, oldValue) => {
  console.log('state 变化了', newValue, oldValue);
});

3.2 监听 getter 函数

javascript 复制代码
const count = ref(0);

watch(() => count.value, (newValue, oldValue) => {
  console.log('count 变化了', newValue, oldValue);
});

3.3 监听多个源

ini 复制代码
const count = ref(0);
const name = ref('Alice');

watch([count, name], ([newCount, newName], [oldCount, oldName]) => {
  console.log('count 或 name 变化了', newCount, newName);
});

4. 为什么props.code 不能直接传给watch

  • props.code 是一个具体的值(number | undefined),而不是一个响应式对象或 getter 函数。
  • watch 的第一个参数需要是一个 响应式对象getter 函数,以便 Vue 能够监听其变化。

5. 总结

  • 报错原因watch 的第一个参数需要是响应式对象或 getter 函数,而不是具体的值。
  • 正确写法 :使用 () => props.code 作为 watch 的第一个参数。
  • 核心思想watch 需要监听的是一个 响应式源,而不是一个具体的值。

如果你对 watch 的用法还有疑问,欢迎在评论区讨论!💬

相关推荐
踢球的打工仔3 分钟前
jquery的基本使用(5)
前端·javascript·jquery
LYFlied4 分钟前
【每日算法】LeetCode 22. 括号生成
数据结构·算法·leetcode·面试·职场和发展
开发者小天5 分钟前
react中的useDebounceEffect用法
前端·react.js·前端框架
想自律的露西西★5 分钟前
js.39. 组合总和
前端·javascript·数据结构·算法
ttod_qzstudio9 分钟前
事件冒泡踩坑记:一个TDesign Checkbox引发的思考
前端·javascript·vue.js·tdesign
IT_陈寒11 分钟前
Vue3性能优化实战:这7个技巧让我的应用加载速度提升40%
前端·人工智能·后端
Reuuse11 分钟前
登录突然失效:Axios 拦截器判空、localStorage 脏数据与环境变量踩坑
开发语言·前端
早川不爱吃香菜12 分钟前
MCP 教程:将 Figma 设计稿转化为前端代码
前端·figma
修炼前端秘籍的小帅14 分钟前
PinMe——极简、免费和无需服务器的开源前端部署工具
前端
XXYBMOOO16 分钟前
基于 HTML5 Canvas 的终端日志流可视化实现(支持多 Pane / 运维模式)
运维·前端·html5