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 的用法还有疑问,欢迎在评论区讨论!💬

相关推荐
学嵌入式的小杨同学12 分钟前
从零打造 Linux 终端 MP3 播放器!用 C 语言实现音乐自由
linux·c语言·开发语言·前端·vscode·ci/cd·vim
芝士爱知识a40 分钟前
2026年AI面试软件推荐
人工智能·面试·职场和发展·大模型·ai教育·考公·智蛙面试
weixin_4255437343 分钟前
TRAE CN3.3.25 构建的Electron简易DEMO应用
前端·typescript·electron·vite·nestjs
Mr Xu_2 小时前
【Vue3 + ECharts 实战】正确使用 showLoading、resize 与 dispose 避免内存泄漏
前端·信息可视化·vue·echarts
0思必得02 小时前
[Web自动化] Selenium设置相关执行文件路径
前端·爬虫·python·selenium·自动化
石去皿2 小时前
大模型面试通关指南:28道高频考题深度解析与实战要点
人工智能·python·面试·职场和发展
雯0609~2 小时前
hiprint:实现项目部署与打印1-官网提供普通html版本
前端·html
C雨后彩虹2 小时前
CAS与其他并发方案的对比及面试常见问题
java·面试·cas·同步·异步·
美团程序员2 小时前
80道经典常见测试面试题
软件测试·面试·职场和发展·软件测试面试
测试秃头怪2 小时前
面试大厂就靠这份软件测试八股文了【含答案】
自动化测试·软件测试·python·功能测试·面试·职场和发展·单元测试