watch 监听props
时间: 2024-12-27 21:29:50 浏览: 8
### 使用 `watch` 监听 Props 变化
在 Vue.js 中,可以通过 `watch` 选项来监听来自父组件传递给子组件的 props 数据变化。对于简单类型的 prop(如字符串、数字等),默认情况下可以直接监听到变化;但对于复杂类型的数据结构(如对象或数组),则可能需要额外配置。
#### 基本语法
当希望监听整个 props 对象时,在子组件内定义如下形式:
```javascript
export default {
props: ['dataList'],
watch: {
dataList(newVal, oldVal) {
console.log('监听引用类型数据dataList');
console.log('new:', newVal);
console.log('old:', oldVal);
}
}
}
```
此方法适用于监听单个 prop 的改变[^1]。
#### 处理深层次嵌套的对象属性变更
如果目标是检测对象内部更深层级的变化,则需启用深度监听模式。此时应调整为以下方式实现:
```javascript
export default {
props: ['obj'],
watch: {
obj: {
handler(newValue) {
console.log(newValue, 'newValue obj');
},
deep: true // 启用深比较机制
}
}
}
```
需要注意的是,默认情况下即使启用了 `deep:true` ,某些场景下仍可能出现无法捕捉新添或移除字段的情况。针对这种情况可采取措施更新整个对象实例以确保能够被侦测到变动[^2]。
#### Vue 3 Composition API 下的做法
在 Vue 3 中采用 setup 函数作为入口点的情况下,推荐利用 `toRefs()` 或者单独使用 `toRef()` 方法来进行更加细粒度的操作。具体做法如下所示:
```typescript
import { defineComponent, onMounted, reactive, toRefs, watch } from "vue";
export default defineComponent({
name: "ChildComponent",
props: ["user"],
setup(props) {
const userProps = toRefs(props);
watch(
() => userProps.user.value,
(newUserValue) => {
console.log(newUserValue); // 当前最新的 user 属性值
},
{ immediate: true, deep: true }
);
return {};
}
});
```
这里展示了如何借助 `toRefs()` 将传入的 props 转换成独立的响应式引用,并对其指定部分实施监视逻辑[^3]。
阅读全文