Man*_*avi 3 checkbox multi-select vue.js vue-multiselect
多选组件的数据属性不会在更改时更新。复选框不会在前端更新。
预期行为:单击复选框时应勾选。
代码链接:https : //jsfiddle.net/bzqd19nt/3/
<div id="app">
<multiselect
select-Label=""
selected-Label=""
deselect-Label=""
v-model="value"
:options="options"
:multiple="true"
track-by="library"
:custom-label="customLabel"
:close-on-select="false"
@select=onSelect($event)
@remove=onRemove($event)
>
<span class="checkbox-label" slot="option" slot-scope="scope" @click.self="select(scope.option)">
{{ scope.option.library }}
<input class="test" type="checkbox" v-model="scope.option.checked" @focus.prevent/>
</span>
</multiselect>
<pre>{{ value }}</pre>
</div>
Run Code Online (Sandbox Code Playgroud)
new Vue({
components: {
Multiselect: window.VueMultiselect.default
},
data: {
value: [],
options: [
{ language: 'JavaScript', library: 'Vue.js', checked: false },
{ language: 'JavaScript', library: 'Vue-Multiselect', checked: false },
{ language: 'JavaScript', library: 'Vuelidate', checked: false }
]
},
methods: {
customLabel(option) {
return `${option.library} - ${option.language}`;
},
onSelect(option) {
console.log('Added');
option.checked = true;
console.log(`${option.library} Clicked!! ${option.checked}`);
},
onRemove(option) {
console.log('Removed');
option.checked = false;
console.log(`${option.library} Removed!! ${option.checked}`);
}
}
}).$mount('#app');
Run Code Online (Sandbox Code Playgroud)
在您的代码中,您调用onSelect并尝试在option函数内更改此函数的参数:
option.checked = true;
Run Code Online (Sandbox Code Playgroud)
这仅影响局部变量option(函数参数)。并且不影响Vue 实例中options数组中data的对象,即绑定复选框的对象。这就是为什么当您单击列表中的一个选项时什么也没有发生的原因。
要修复它,请在options数组中找到适当的元素并更改它:
let index = this.options.findIndex(item => item.library==option.library);
this.options[index].checked = true;
Run Code Online (Sandbox Code Playgroud)
这是修复的代码片段:
option.checked = true;
Run Code Online (Sandbox Code Playgroud)
let index = this.options.findIndex(item => item.library==option.library);
this.options[index].checked = true;
Run Code Online (Sandbox Code Playgroud)
new Vue({
components: {
Multiselect: window.VueMultiselect.default
},
data: {
value: [],
options: [
{ language: 'JavaScript', library: 'Vue.js', checked: false },
{ language: 'JavaScript', library: 'Vue-Multiselect', checked: false },
{ language: 'JavaScript', library: 'Vuelidate', checked: false }
]
},
methods: {
customLabel (option) {
return `${option.library} - ${option.language}`
},
onSelect (option) {
console.log("Added");
let index = this.options.findIndex(item => item.library==option.library);
this.options[index].checked = true;
console.log(option.library + " Clicked!! " + option.checked);
},
onRemove (option) {
console.log("Removed");
let index = this.options.findIndex(item => item.library==option.library);
this.options[index].checked = false;
console.log(option.library + " Removed!! " + option.checked);
}
}
}).$mount('#app')Run Code Online (Sandbox Code Playgroud)