watch深度监听一个对象。为什么select下拉可以监听。input输入改变监听不到呢????
watch{
withStoneList: {
handler: function (val, oldVal) {
console.log("peibian")
console.log(val)
console.log(oldVal)
},
deep: true
}
}
withStoneList是个数组。数组的每一项是个对象。对象里面的属性,有的绑定select下拉,有的绑定input输入框。我发现只有下拉选项改变才会触发监听。input中输入数据并不会触发watch是为什么?
输入11不会触发监听,为什么
如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。
绑定邮箱获取回复消息
由于您还没有绑定你的真实邮箱,如果其他用户或者作者回复了您的评论,将不能在第一时间通知您!
发布评论
评论(4)
v-model
就是一个语法糖,监听了@input
事件<input type="text" :value="val" @input="val=$event.target.value" />
而
v-model.lazy
,则是监听了@change
事件<input type="text" :value="val" @change="val=$event.target.value" />
你可以在
input/change
事件,触发一个自定义的method
,主动赋值并进行其它操作case
谢邀
input等form表单的输入框,可以使用v-model
list下面很多对象。对象里面有很多属性。我list.push({a:00,b:00,c:00}),进去一个对象。但是input绑定的val属性我没有写。所以导致input输入时,会在{a:00,b:00,c:00}下面创建val。所以在修改就不会触发watch。应该list.push({a:00,b:00,c:00,val:''})这样代码就没有问题了
看不到完整代码,因此不知道是什么原因导致的