在父组件中需要根据子组件data的变化做一些操作(不能修改子组件),但watch不到变化
现在做法:
在父组件:
computed: {
// 滚动的距离
moveY: function () {
return this.$refs.scrollbar.moveY || 0
}
},
watch: {
moveY (val) {
console.log(val)
}
}
问题:this.$refs.scrollbar.moveY值变化了,但console.log(val)没有输出
如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。
绑定邮箱获取回复消息
由于您还没有绑定你的真实邮箱,如果其他用户或者作者回复了您的评论,将不能在第一时间通知您!
发布评论
评论(2)
这样写吧
子组件值变化的时候,
$emit('move-y-change',value)
到父组件.如果你用
$refs.scrollbar.moveY
,父子组件就多了一个隐性的耦合。那样以后子组件的moveY
被改掉了,你都不知道。