我希望始终至少选中一个复选框,但我混合了v-model
和的概念:checked
。
医生说:
v-model
将忽略在任何表单元素上找到的初始或属性value
。它将始终将 Vue 实例数据视为事实来源。checked
selected
我可以阻止我的模型被修改,但我不能阻止复选框被选中......
一些代码:
模板
<div class="wrapper" v-for="(s, id) in userOutputSeries" :key="id">
<input type="checkbox" :id="id" :value="id" @change="preventIfLessThanOneChecked" :checked="s.active">
<label :for="id">{{ s.display }}</label>
</div>
该模型userOutputSeries
data () {
return {
userOutputSeries: {
foo: {
display: 'Awesome Foo',
active: true
},
bar: {
display: 'My Bar',
active: false
}
}
}
}
处理preventIfLessThanOneChecked
程序
preventIfLessThanOneChecked (event) {
// I don't update the model so it stay at the same state
// But only need to count the active series and do what we want.
console.log(event.target.value, event.target.checked)
}
有什么想法可以阻止本机复选框传播吗?