vue watch 数据监听

vue watch 监听 用于检测数据变化

1. 简单用法
data() {
  return {
    isEdit: false
  }
},
watch: {
  isEdit(newVal, oldVal) {
    console.log(`${newVal},${oldVal}`)
  }
},
2. 深度监听 (主要用于 数组 和 对象 类型数据的监听)
data() {
  return {
    form: {},
  }
},
watch: {
  form(newVal, oldVal) {
    console.log(oldVal)
    console.log(newVal)
  }
},
methods: {
  handleChangeForm() {
    this.form = {
      id: 'id',
      name: 'name',
      type: 'type'
    }
    //此时watch能监听到数据的变化
  },
  handleChangeFormItem() {
    this.form.id = '001'
    //当改变对象的某一项时,简单的数据监听无效,需要添加deep:true,属性
  }
}
watch: {
  form: {
    handler(newVal, oldVal) {
      console.log(oldVal)
      console.log(newVal)
    },
    deep: true //深度监听
  }
}
3. 立即执行 (初始值时立即执行handler函数)
watch: {
  form: {
    handler(newVal, oldVal) {
      console.log(oldVal)
      console.log(newVal)
    },
    deep: true, //深度监听
    immediate: true //立即执行
  }
}
4. 只监听对象种某一个属性的值,使用字符串的形式
watch: {
  'form.id': {
    handler(newVal, oldVal) {
      console.log(oldVal)
      console.log(newVal)
    },
    deep: true, //深度监听
    immediate: true //立即执行
  }
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值