使用在v-model
组件内的视图和数据模型之间创建双向绑定。并且视图交互可以向父组件发出事件。
但是,有可能让子组件中的数据模型更改向父组件发出事件吗?
因为只要用户是单击复选框的人,父母和孩子的事情都很好(数据模型更新并发出事件)。但是,如果我拉起 Vue 开发工具并切换子组件数据中的复选框,则来自 的双向绑定v-model
将在 CHILD 组件内进行适当的更新,但没有任何东西可以转移到父组件(我怀疑是因为不发出事件)。
如何确保父组件“知道”子组件中的数据更改?我认为这必须以某种方式实现......如果不是从子组件发出,也许有某种方法可以让父组件“监视”子组件的数据?
感谢您的任何帮助或指导!在此期间,我将继续阅读并寻找答案!
子组件
<template>
<div class="list-item" v-on:click="doSomething">
<input type="checkbox" v-model="checked">
<label v-bind:class="{ checked: checked }">{{ name }}</label>
</div>
...
</template>
<script>
...
data: function() {
return {
checked: false,
}
},
methods: {
doSomething() {
...
this.$emit('doSomething', this)
}
}
</script>
父组件
<template>
<ChildComponent v-on:doSomething="getItDone"></ChildComponent>
...
</template>
<script>
...
methods: {
getItDone(target) {
...
}
}
</script>
更新:在玩了更多@IVO GELOV 的解决方案之后,我现在遇到的问题是,当涉及多个子组件时,由于父级的 myBooleanVar 的一个奇异值驱动整个事情,选中一个框child component 导致检查所有子组件。
因此,在视图和数据操作都将其移交给父级方面绝对是进步,但我仍在试图弄清楚如何“隔离”这种情况,以便只有一个被执行的子组件被拖入聚会...