watch 监听器
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<meta http-equiv="X-UA-Compatible" content="ie=edge">
<title>Document</title>
</head>
<body>
<div id="app">
<h1>{{name}}</h1>
<h1>{{age}}</h1>
<input type="text" v-model="remark">
</div>
<script src="./vue.js"></script>
<script>
new Vue({
data: {
name: '赵胤祯',
age: 60,
gender: '男',
contact: {
email: '9868785875@qq.com',
phone: '18924367819'
},
remark: '暂无'
},
methods: {
onAgeChange: function (newAge, oldAge) {
console.log(newAge, oldAge)
}
},
watch: {
// 监听 name 属性的变化
name: function (newName, oldName) {
console.log(newName, oldName)
},
// 当 data 选项中 age 属性的值变化时,执行 methods 选项中 onAgeChange 方法
age: 'onAgeChange',
// 当 data 选项中 contact 属性的值变化时,执行对应的处理方法
// 注意:contact 对象中属性的值发生变化时并不会触发该方法,例如,contact.phone = '110'
// contact: function (newContact, oldContact) {
// console.log(newContact, oldContact)
// },
// 当 contact 对象中 phone 属性的值发生变化时,执行该方法,
// 注意:email 属性变化时,并不会触发该方法
// 'contact.phone': function (newPhone, oldPhone) {
// console.log(newPhone, oldPhone)
// },
// 监听 contact 对象中所有属性的变化,
// 注意,由于 newValue 和 oldValue 指向同一个对象(contact),
// 因此 newValue 和 oldVallue 中的值都是相同的。
contact: {
handler: function (newValue, oldValue) {
console.log(newValue.email, oldValue.email)
console.log(newValue.phone, oldValue.phone)
},
deep: true // 表示深度监视,不仅监视 contact 属性值的变化,还是会监视 contact 内的属性值的变化。
},
gender: {
handler: function (newGender, oldGender) {
console.log(newGender, oldGender)
},
// 如果你想让处理方法在监听开始时执行一次,可以设置以下属性
// 也就是或,该回调将会在侦听开始之后被立即调用
immediate: true
},
// 当 remark 属性值发生变化时,数组中的处理方法都会执行
remark: [function (newRemark, oldRemark) {
console.log('remark handler1', newRemark, oldRemark)
}, function (newRemark, oldRemark) {
console.log('remark handler2', newRemark, oldRemark)
}]
}
}).$mount('#app')
</script>
</body>
</html>
本文作者:张尊娟
本文链接:https://www.cnblogs.com/wszzj/p/12291872.html
版权声明:本作品采用知识共享署名-非商业性使用-禁止演绎 2.5 中国大陆许可协议进行许可。
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
· 开发者必知的日志记录最佳实践
· SQL Server 2025 AI相关能力初探
· Linux系列:如何用 C#调用 C方法造成内存泄露
· AI与.NET技术实操系列(二):开始使用ML.NET
· 被坑几百块钱后,我竟然真的恢复了删除的微信聊天记录!
· 【自荐】一款简洁、开源的在线白板工具 Drawnix
· 没有Manus邀请码?试试免邀请码的MGX或者开源的OpenManus吧
· 园子的第一款AI主题卫衣上架——"HELLO! HOW CAN I ASSIST YOU TODAY
· 无需6万激活码!GitHub神秘组织3小时极速复刻Manus,手把手教你使用OpenManus搭建本