watch深度监听

24 篇文章 1 订阅
19 篇文章 0 订阅

如果监听的数据是一个对象或者是数组,那么普通的监听是监听不到数据变化的,此时就需要用到watch的deep属性

<template>
  <div>
    <input v-model="userInfo.name" type="text" />
    <input v-model="userInfo.age" type="text" />
  </div>
</template>
<script>
export default {
  data() {
    return {
      userInfo: {
        name: 'zs',
        age: 20
      }
    }
  },
  watch: {

	// 以下两种方法按需使用


    // 第一种方法只有name发生变化的时候触发
    // 此时如果在age输入框里面输入是不会触发此打印的,因为它监听的只是name的变化
    'userInfo.name': value => {
      console.log('name', value)
    },

    // 第二种方法是只要userInfo对象里面的某一个变量发生了变化就会触发
    // 这个时候无论是在name输入框还是age输入框输入都会触发此方法,
    // 因为只要userInfo里面的任何一个值有变化都会监听到
    userInfo: {
      handler(value) {
        console.log('userInfo', value)
      },
      deep: true
    }
  },
  methods: {}
}
</script>

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值