vue实现多选列表
Vue 实现多选列表的方法
使用 v-model 绑定数组
在 Vue 中,可以利用 v-model 指令绑定一个数组来实现多选功能。当用户选择多个选项时,选中的值会自动添加到数组中。
<template>
<div>
<select v-model="selectedItems" multiple>
<option v-for="item in items" :key="item.id" :value="item.value">
{{ item.label }}
</option>
</select>
<p>已选项目: {{ selectedItems }}</p>
</div>
</template>
<script>
export default {
data() {
return {
items: [
{ id: 1, label: '选项1', value: 'value1' },
{ id: 2, label: '选项2', value: 'value2' },
{ id: 3, label: '选项3', value: 'value3' }
],
selectedItems: []
};
}
};
</script>
使用复选框实现多选
另一种常见的方式是使用复选框(checkbox)来实现多选列表。通过 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.label }}</label>
</div>
<p>已选项目: {{ selectedItems }}</p>
</div>
</template>
<script>
export default {
data() {
return {
items: [
{ id: 1, label: '选项1', value: 'value1' },
{ id: 2, label: '选项2', value: 'value2' },
{ id: 3, label: '选项3', value: 'value3' }
],
selectedItems: []
};
}
};
</script>
使用第三方组件库
如果需要更丰富的功能(如搜索、分组等),可以借助第三方组件库(如 Element UI、Vuetify 或 Ant Design Vue)实现多选列表。
以 Element UI 为例:
<template>
<div>
<el-select v-model="selectedItems" multiple placeholder="请选择">
<el-option
v-for="item in items"
:key="item.id"
:label="item.label"
:value="item.value"
/>
</el-select>
<p>已选项目: {{ selectedItems }}</p>
</div>
</template>
<script>
export default {
data() {
return {
items: [
{ id: 1, label: '选项1', value: 'value1' },
{ id: 2, label: '选项2', value: 'value2' },
{ id: 3, label: '选项3', value: 'value3' }
],
selectedItems: []
};
}
};
</script>
自定义多选组件
如果需要完全自定义的多选列表,可以封装一个组件,通过事件和状态管理实现多选逻辑。
<template>
<div>
<div
v-for="item in items"
:key="item.id"
@click="toggleSelection(item)"
:class="{ 'selected': selectedItems.includes(item.value) }"
>
{{ item.label }}
</div>
<p>已选项目: {{ selectedItems }}</p>
</div>
</template>
<script>
export default {
data() {
return {
items: [
{ id: 1, label: '选项1', value: 'value1' },
{ id: 2, label: '选项2', value: 'value2' },
{ id: 3, label: '选项3', value: 'value3' }
],
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>
注意事项
- 如果选项较多,建议添加搜索或分页功能以提升用户体验。
- 对于移动端,可以使用
multiple属性的<select>或专门的移动端 UI 库。 - 确保绑定的数组初始化为空数组,否则可能导致绑定失效。







