vue中实现多选
Vue 中实现多选功能
在 Vue 中实现多选功能可以通过多种方式完成,常见的有使用原生 HTML 的 <select multiple>、复选框组或第三方 UI 库。以下是几种常见的实现方法:
使用 <select multiple> 实现多选
通过 HTML 原生的 <select> 元素设置 multiple 属性,允许用户选择多个选项。

<template>
<select v-model="selectedItems" multiple>
<option v-for="item in items" :key="item.id" :value="item.value">
{{ item.text }}
</option>
</select>
</template>
<script>
export default {
data() {
return {
items: [
{ id: 1, value: 'apple', text: 'Apple' },
{ id: 2, value: 'banana', text: 'Banana' },
{ id: 3, value: 'orange', text: 'Orange' },
],
selectedItems: [],
};
},
};
</script>
使用复选框组实现多选
通过 v-model 绑定一个数组来管理多个复选框的选中状态。
<template>
<div>
<div v-for="item in items" :key="item.id">
<input
type="checkbox"
:id="item.id"
:value="item.value"
v-model="selectedItems"
/>
<label :for="item.id">{{ item.text }}</label>
</div>
</div>
</template>
<script>
export default {
data() {
return {
items: [
{ id: 1, value: 'apple', text: 'Apple' },
{ id: 2, value: 'banana', text: 'Banana' },
{ id: 3, value: 'orange', text: 'Orange' },
],
selectedItems: [],
};
},
};
</script>
使用第三方 UI 库实现多选
许多 UI 库(如 Element UI、Vuetify、Ant Design Vue)提供了封装好的多选组件,功能更丰富且易于使用。

以 Element UI 的 el-select 为例:
<template>
<el-select v-model="selectedItems" multiple placeholder="请选择">
<el-option
v-for="item in items"
:key="item.value"
:label="item.text"
:value="item.value"
>
</el-option>
</el-select>
</template>
<script>
export default {
data() {
return {
items: [
{ value: 'apple', text: 'Apple' },
{ value: 'banana', text: 'Banana' },
{ value: 'orange', text: 'Orange' },
],
selectedItems: [],
};
},
};
</script>
自定义多选组件
如果需要更灵活的功能,可以自定义一个多选组件,结合复选框或其他交互方式。
<template>
<div>
<div
v-for="item in items"
:key="item.id"
@click="toggleSelection(item)"
:class="{ selected: selectedItems.includes(item.value) }"
>
{{ item.text }}
</div>
</div>
</template>
<script>
export default {
data() {
return {
items: [
{ id: 1, value: 'apple', text: 'Apple' },
{ id: 2, value: 'banana', text: 'Banana' },
{ id: 3, value: 'orange', text: 'Orange' },
],
selectedItems: [],
};
},
methods: {
toggleSelection(item) {
const index = this.selectedItems.indexOf(item.value);
if (index === -1) {
this.selectedItems.push(item.value);
} else {
this.selectedItems.splice(index, 1);
}
},
},
};
</script>
<style>
.selected {
background-color: #f0f0f0;
}
</style>
以上方法可以根据实际需求选择,原生方式适合简单场景,而第三方库或自定义组件适合复杂需求。






