Vue侦听器的使用
文章目录
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的使用