Vue侦听器的使用

Vue侦听器的使用

文章目录

  • Vue侦听器的使用
    • 1.什么是侦听器
    • 2.如何使用侦听器
    • 3.vm.$watch API的使用
    • 4.vm.$watch的返回值
    • 5.vm.$watch()中选项的使用
    • 6.回调内部调用一个取消侦听的函数
    • 7.实例展示
      • 1.watch的使用
      • 2.this.$watch()的使用案例

1.什么是侦听器

虽然计算属性在大多数情况下更合适,但有时也需要一个自定义的侦听器。这就是为什么 Vue 通过 `watch` 选项提供了一个更通用的方法,来响应数据的变化。当需要在数据变化时**执行异步或开销较大**的操作时,这个方式是最有用的。
说白了,就是为了响应数据的变化。

2.如何使用侦听器

data: {
    question: '',
    answer: 'I cannot give you an answer until you ask a question!'
  },
  watch: {
    // 如果 `question` 发生改变,这个函数就会运行
    question: function (newQuestion, oldQuestion) {
      this.answer = 'Waiting for you to stop typing...'
      this.debouncedGetAnswer()
    }
  },
  
  其中question:代表要监听的数据。
  function(new,old):其中new代表要监听数据的新的值,old代表原来的值。
  
  当然:除了 watch 选项之外,您还可以使用命令式的 vm.$watch API。

3.vm.$watch API的使用

vm.$watch( expOrFn, callback, [options] )
参数:
{string | Function} expOrFn
{Function | Object} callback
{Object} [options]:
    {boolean} deep
    {boolean} immediate
返回值:{Function} unwatch


用法:

观察 Vue 实例上的一个表达式或者一个函数计算结果的变化。回调函数得到的参数为新值和旧值。表达式只接受简单的键路径。对于更复杂的表达式,用一个函数取代。
注意:表达式只接受简单的键路径
即,这次它要监听的数据可以是简单的表达式也可以是函数

例如监听函数的变化:
----
// 函数
vm.$watch(
  function () {
    // 表达式 `this.a + this.b` 每次得出一个不同的结果时
    // 处理函数都会被调用。
    // 这就像监听一个未被定义的计算属性
    return this.a + this.b发生变化时,就会执行下面的回调函数
  },
  function (newVal, oldVal) {
    // 做点什么
  }
)

即当this.a + this.b发生变化时,就会执行下面的回调函数

4.vm.$watch的返回值

vm.$watch 返回一个取消观察函数,用来停止触发回调:

var unwatch = vm.$watch('a', cb)
// 之后取消观察
unwatch()
即:该侦听器执行之后就会停止触发

5.vm.$watch()中选项的使用

1.deep:
为了发现对象内部值的变化,可以在选项参数中指定 deep: true。注意监听数组的变更不需要这么做。

vm.$watch('someObject', callback, {
  deep: true
})
vm.someObject.nestedValue = 123
// callback is fired



2.immediate:

在选项参数中指定 immediate: true 将立即以表达式的当前值触发回调:

vm.$watch('a', callback, {
  immediate: true
})
// 立即以 `a` 的当前值触发回调

6.回调内部调用一个取消侦听的函数

如果你仍然希望在回调内部调用一个取消侦听的函数,你应该先检查其函数的可用性:

var unwatch = vm.$watch(
  'value',
  function () {
    doSomething()
    if (unwatch) {
      unwatch()
    }
  },
  { immediate: true }
)

7.实例展示

1.watch的使用

Vue侦听器的使用_第1张图片
Vue侦听器的使用_第2张图片

2.this.$watch()的使用案例

Vue侦听器的使用_第3张图片

你可能感兴趣的:(Vue,vue)