watch监听vue2与vue3的写法

watch的属性值

TypeScript 复制代码
handler:回调函数, 即监听到变化时应该执行的函数,可以是单独的函数或带有 immediate 和 deep 属性的对象
    watch: {
      someProperty: function(newVal, oldVal) {
        // 处理逻辑
      }
    }


deep: 其值是true或false, 当属性值是对象或数组时,深度观察会监控对象内部所有层级的变化。
    watch: {
      someObject: {
        handler(newVal, oldVal) {
              // 处理逻辑
        },
        deep: true
      }
    }


immediate: 值是true或false,首次绑定时立即执行回调函数
    watch: {
      someProperty: {
        handler(newVal, oldVal) {
          // 处理逻辑
        },
        immediate: true
      }
    }

vue2写法:

TypeScript 复制代码
//基本用法
  watch:{
    avatar(navl,oval){
        console.log(navl,'navl');
        console.log(oval,'oval');
    }
  },
//深度监听 
watch: {
    user: {
      handler(nval,oval) {
         console.log(nval,oval);
      },
      deep: true,
    }
  },
//立即执行
watch: {
    user: {
      handler(nval,oval) {
         console.log(nval,oval);
      },
      immediate: true
    }
  },
//观察数组中特定项的变化
  watch: {
    'user[0]': function(newVal, oldVal) {
      console.log('user[0] changed from', oldVal, 'to', newVal);
    }
//监听多个数据源
  watch: {
    property1(newVal, oldVal) {
      console.log('property1 changed from', oldVal, 'to', newVal);
    },
    property2(newVal, oldVal) {
      console.log('property2 changed from', oldVal, 'to', newVal);
    }
  }

vue3写法:

TypeScript 复制代码
import { watch } from 'vue';
//基本用法
watch(avatar, (newVal, oldVal) => {
   console.log('avatarchanged from', oldVal, 'to', newVal);
});

//深度管察
watch(
   () => user,
   (nval,oval) => {
      console.log(val, oval)
   },
    { deep:true },
)

//立即执行
watch(
   () => user,
   (nval,oval) => {
      console.log(val, oval)
   },
    { immediate: true },
)

//使用回调函数对象
watch(
   someProperty,
    {
       handler(newVal, oldVal) {
        console.log('someProperty changed from', oldVal, 'to', newVal);
     },
       immediate: true,
       deep: true
      }
    );
相关推荐
前端风云志2 分钟前
typescript结构化类型应用两例
javascript
杨进军20 分钟前
React 创建根节点 createRoot
前端·react.js·前端框架
ModyQyW35 分钟前
用 AI 驱动 wot-design-uni 开发小程序
前端·uni-app
说码解字42 分钟前
Kotlin lazy 委托的底层实现原理
前端
gnip1 小时前
总结一期正则表达式
javascript·正则表达式
Q_970956391 小时前
java+vue+SpringBoo校园失物招领网站(程序+数据库+报告+部署教程+答辩指导)
java·数据库·vue.js
爱分享的程序员1 小时前
前端面试专栏-算法篇:18. 查找算法(二分查找、哈希查找)
前端·javascript·node.js
翻滚吧键盘1 小时前
vue 条件渲染(v-if v-else-if v-else v-show)
前端·javascript·vue.js
vim怎么退出1 小时前
万字长文带你了解微前端架构
前端·微服务·前端框架
你这个年龄怎么睡得着的1 小时前
为什么 JavaScript 中 'str' 不是对象,却能调用方法?
前端·javascript·面试