Vue 3 Watch 监听 Props 的踩坑记录

问题描述

最近在写一个基础下拉组件时,遇到了一个关于 watch 监听 props 值变化的问题。起初的代码是这样的:

javascript 复制代码
// ❌ 错误示例
watch([options, props.modelValue], ([newOptions, newModelValue]) => {
  // 发现无法正确获取到 props.modelValue 的最新值
})

问题分析

在排查过程中发现,直接使用 props.modelValue 作为监听源时,只能获取到 props 的初始值,而无法检测到后续的变化。

解决方案

经过查阅 Vue 3 文档和社区讨论,发现需要使用箭头函数来包装 props 值:

javascript 复制代码
// ✅ 正确示例
watch([options, () => props.modelValue], ([newOptions, newModelValue]) => {
 // 现在可以正确获取到 props.modelValue 的最新值了
})

原理解析

不使用箭头函数时

javascript 复制代码
const value = props.modelValue;  // 直接访问,只获取一次值
watch(value, () => {})  // 监听的是一个静态值

使用箭头函数时

javascript 复制代码
const getter = () => props.modelValue;  // 创建 getter 函数
watch(getter, () => {})  // 每次都会重新执行 getter 获取最新值

响应式追踪示例

javascript 复制代码
// 在组件中的实际应用
watch(
  [
    options,  // ref 对象可以直接监听
    () => props.modelValue  // props 需要通过 getter 函数监听
 ],
  ([newOptions, newValue]) => {
    // 能够正确响应两个值的变化
  }
)

总之,使用箭头函数可以确保:

  1. 正确追踪响应式依赖
  2. 每次都能获取到最新的 prop 值
  3. 保持响应式系统的完整性

总结

  1. 监听 ref/reactive 对象:可以直接使用
  2. 监听 props:使用箭头函数包装
  3. 需要深度监听时:添加 { deep: true } 配置
相关推荐
竹林81815 小时前
用 wagmi v2 + WebSocket 硬磕 NFT 上架失败:一个前端开发者踩过的实时状态同步坑
javascript·next.js
豹哥学前端15 小时前
告别割裂式学习:待办清单项目,一次性掌握数组、本地存储与事件委托
前端·javascript
JYeontu15 小时前
照片墙太死板?做一个会随风摇摆的绳串图片交互效果
前端·javascript·css
2501_9159214315 小时前
HTTPS前端劫持 新一代流量劫持解决方案
前端·网络协议·ios·小程序·https·uni-app·iphone
Yue栎廷15 小时前
邪修:Markdown加粗语法**本土化改造
前端·javascript·人工智能
爱怪笑的小杰杰15 小时前
优化 UniApp 日历组件的多语言切换:告别 setLocale 引起的 App 重启
java·前端·uni-app
有所事事15 小时前
如何让AI写代码越写越像你
前端·后端
Allen正心正念202515 小时前
前端——Node.js&npm,学点前端的东西
前端·npm·node.js
西瓜有点饿15 小时前
前端基础知识之---Content-Type有哪些格式
前端
小歪 | 前端15 小时前
VUE_运行Vue项目Network: unavailable问题解决
前端·javascript·vue.js