Vue中的watch方法

257 阅读1分钟

Vue中的watch方法

1.普通用法

通过watch监听searchValue的变化

export default {
  data() {
    return {
      searchValue: ''
    }
  },
  watch: {
    // 在值发生变化之后,重新加载数据
    searchValue(newValue, oldValue) {
      // 判断搜索
      if (newValue !== oldValue) {
        this.$_loadData()
      }
    }
  },
  methods: {
    $_loadData() {
      // 重新加载数据,此处需要通过函数防抖
    }
  }
}

2.立即触发

searchValue初始化时就触发$_loadData()

export default {
  data() {
    return {
      searchValue: ''
    }
  },
  watch: {
    // 在值发生变化之后,重新加载数据
    searchValue(newValue, oldValue) {
      // 判断搜索
      if (newValue !== oldValue) {
        this.$_loadData()
      }
    }
  },
  methods: {
    $_loadData() {
      // 重新加载数据,此处需要通过函数防抖
    }
  }
}

3.深度监听

也就是说监听一个对象的属性,由于对象的newValue===oldValue,按照前面方法的判断会失效。需要使用深度监听的方式,这样newValue和oldValue对应的是对象属性的值。

export default {
  data() {
    return {
      formData: {
        name: '',
        sex: '',
        age: 0,
        deptId: ''
      }
    }
  },
  watch: {
    // 在值发生变化之后,重新加载数据
    formData: {
      // 需要注意,因为对象引用的原因, newValue和oldValue的值一直相等
      handler(newValue, oldValue) {
        // 在这里标记页面编辑状态
      },
      // 通过指定deep属性为true, watch会监听对象里面每一个值的变化
      deep: true
    }
  }
}

此外还有两种方法可以监听对象属性的值

(1)computed计算方法
export default {
  data() {
    return {
      formData: {
        name: '',
        sex: '',
        age: 0,
        deptId: ''
      }
    }
  },
  computed:{
    name(){return this.formData.name;}
  }
  watch: {
    // 在值发生变化之后,重新加载数据
    name(newValue,oldValue){
    console.log(`${newValue},${oldValue}`)
    }
    }
}
(2)用字符串表示对象的属性调用
export default {
  data() {
    return {
      formData: {
        name: '',
        sex: '',
        age: 0,
        deptId: ''
      }
    }
  },
  watch: {
    // 在值发生变化之后,重新加载数据
    ”formData.name’(newValue,oldValue){
    console.log(`${newValue},${oldValue}`)
    }
    }
}

4.随时监听,随时取消,$watch

export default {
  data() {
    return {
      formData: {
        name: '',
        age: 0
      }
    }
  },
  created() {
    this.$_loadData()
  },
  methods: {
    // 模拟异步请求数据
    $_loadData() {
      setTimeout(() => {
        // 先赋值
        this.formData = {
          name: '子君',
          age: 18
        }
        // 等表单数据回填之后,监听数据是否发生变化
        const unwatch = this.$watch(
          'formData',
          () => {
            console.log('数据发生了变化')
          },
          {
            deep: true
          }
        )
        // 模拟数据发生了变化
        setTimeout(() => {
          this.formData.name = '张三'
        }, 1000)
      }, 1000)
    }
  }
}

通过this.watch监听数据变化,需要注意的是this.watch监听数据变化,需要注意的是this.watch返回的是一个unwatch函数,通过调用unwatch函数可以实现取消数据监听。