Vue中的watch是如何实现深度监听的?

简介: Vue中的watch是如何实现深度监听的?

在 Vue 中,可以使用watch选项来监听数据的变化。如果需要深度监听对象中的数据变化,可以使用deep: true选项。例如:

<template>
  <div>
    <input type="text" v-model="obj.a" @input="handleInput" />
    <input type="text" v-model="obj.b" @input="handleInput" />
    <p>{
   {
    obj }}</p>
  </div>
</template>

<script>
export default {
   
  data() {
   
    return {
   
      obj: {
    a: '', b: '' },
    };
  },
  watch: {
   
    obj: {
   
      handler(newValue, oldValue) {
   
        console.log('obj changed:', newValue, oldValue);
      },
      deep: true,
    },
  },
  methods: {
   
    handleInput(event) {
   
      this.obj[event.target.name] = event.target.value;
    },
  },
};
</script>

在上述示例中,我们使用watch选项监听obj对象的变化。当obj对象中的任何一个属性发生变化时,都会触发handler函数。同时,我们使用deep: true选项开启深度监听,这样当obj对象中的子属性发生变化时,也会触发handler函数。

目录
相关文章
|
1天前
|
JavaScript
|
1天前
|
JavaScript 前端开发
Vue,如何引入样式文件
Vue,如何引入样式文件
|
1天前
|
JavaScript
|
1天前
|
JavaScript
Vue搭配ELEMENT之后,右侧点击栏点击跳转到空白页解决方法
Vue搭配ELEMENT之后,右侧点击栏点击跳转到空白页解决方法
|
1天前
|
JavaScript
vue : 无法将“vue”项识别为 cmdlet、函数、脚本文件或可运行程序的名称。请检查名称的拼写,如果包括路径,请确保 路径正确,然后再试一次。
vue : 无法将“vue”项识别为 cmdlet、函数、脚本文件或可运行程序的名称。请检查名称的拼写,如果包括路径,请确保 路径正确,然后再试一次。
|
JavaScript 前端开发
vue通过监听实现相同路径的视图重新加载
最近在做一个项目,前端菜单路径如下: { path: '/oa/workflow/process/:status', component: sys_workflow_process, ...
1235 0
|
1天前
|
JavaScript 前端开发 API
|
1天前
|
JavaScript 前端开发 网络架构
Vue如何实现页面跳转路由,实现单页面跳转
Vue如何实现页面跳转路由,实现单页面跳转
|
2天前
|
JavaScript 前端开发
Vue组件生命周期深度剖析:从创建到销毁的八大钩子实战指南
Vue组件生命周期深度剖析:从创建到销毁的八大钩子实战指南
|
1天前
|
JavaScript