首页 / VUE / vue中watch监听的高阶使用
vue中watch监听的高阶使用
内容导读
互联网集市收集整理的这篇技术教程文章主要介绍了vue中watch监听的高阶使用,小编现在分享给大家,供广大互联网技能从业者学习和参考。文章包含1401字,纯文字阅读大概需要3分钟。
内容图文
watch高阶使用
立即执行
watch 是在监听属性改变时才会触发,有些时候,我们希望在组件创建后 watch 能够立即执行
可能想到的的方法就是在 create 生命周期中调用一次,但这样的写法不优雅,或许我们可以使用这样的方法
export default {
data() {
return {
msg: ‘‘
}
},
watch: {
msg: {
handler: ‘sayMsg‘,
immediate: true
}
},
methods: {
sayMsg() {
console.log(this.msg)
}
}
}
深度监听
在监听对象时,对象内部的属性被改变时无法触发 watch ,我们可以为其设置深度监听
export default {
data() {
return {
obj: {
name: ‘张三‘,
msg: {
sex: ‘男‘,
age: 18,
tel: 18888888888
}
}
}
},
watch: {
obj: {
handler: ‘sayMsg‘,
// immediate: true
deep: true
}
},
methods: {
sayMsg() {
console.log(this.obj.msg.age)
}
}
}
触发监听执行多个方法
export default {
data: {
name: ‘Joe‘
},
watch: {
name: [
‘sayName1‘,
function(newVal, oldVal) {
this.sayName2()
},
{
handler: ‘sayName3‘,
immaediate: true
}
]
},
methods: {
sayName1() {
console.log(‘sayName1==>‘, this.name)
},
sayName2() {
console.log(‘sayName2==>‘, this.name)
},
sayName3() {
console.log(‘sayName3==>‘, this.name)
}
}
}
watch监听多个变量
watch本身无法监听多个变量。但我们可以将需要监听的多个变量通过计算属性返回对象,再监听这个对象来实现“监听多个变量”
export default {
data() {
return {
msg1: ‘apple‘,
msg2: ‘banana‘
}
},
compouted: {
msgObj() {
const { msg1, msg2 } = this
return {
msg1,
msg2
}
}
},
watch: {
msgObj: {
handler(newVal, oldVal) {
if (newVal.msg1 != oldVal.msg1) {
console.log(‘msg1 is change‘)
}
if (newVal.msg2 != oldVal.msg2) {
console.log(‘msg2 is change‘)
}
},
deep: true
}
}
}
原文:https://www.cnblogs.com/wangqingjiu/p/12836369.html
内容总结
以上是互联网集市为您收集整理的vue中watch监听的高阶使用全部内容,希望文章能够帮你解决vue中watch监听的高阶使用所遇到的程序开发问题。 如果觉得互联网集市技术教程内容还不错,欢迎将互联网集市网站推荐给程序员好友。
内容备注
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 gblab@vip.qq.com 举报,一经查实,本站将立刻删除。
内容手机端
扫描二维码推送至手机访问。