vue实现多选效果
Vue 实现多选效果的方法
使用 v-model 绑定数组
在 Vue 中,可以通过 v-model 绑定一个数组来实现多选效果。适用于复选框组(checkbox)或下拉多选(select multiple)。

<template>
<div>
<h3>选择你喜欢的编程语言:</h3>
<label v-for="lang in languages" :key="lang">
<input type="checkbox" v-model="selectedLanguages" :value="lang" />
{{ lang }}
</label>
<p>已选择:{{ selectedLanguages }}</p>
</div>
</template>
<script>
export default {
data() {
return {
languages: ['JavaScript', 'Python', 'Java', 'C++'],
selectedLanguages: []
};
}
};
</script>
使用 v-for 动态渲染多选列表
通过 v-for 动态生成多选选项,适合选项数量较多或动态加载的场景。

<template>
<div>
<h3>选择兴趣标签:</h3>
<div v-for="tag in tags" :key="tag.id">
<input
type="checkbox"
v-model="selectedTags"
:value="tag.id"
:id="'tag-' + tag.id"
/>
<label :for="'tag-' + tag.id">{{ tag.name }}</label>
</div>
<p>已选标签ID:{{ selectedTags }}</p>
</div>
</template>
<script>
export default {
data() {
return {
tags: [
{ id: 1, name: '前端开发' },
{ id: 2, name: '后端开发' },
{ id: 3, name: '人工智能' }
],
selectedTags: []
};
}
};
</script>
使用第三方组件库(如 Element UI)
对于更复杂的需求,可以使用第三方 UI 库(如 Element UI、Ant Design Vue)提供的多选组件。
<template>
<div>
<el-select v-model="selectedValues" multiple placeholder="请选择">
<el-option
v-for="item in options"
:key="item.value"
:label="item.label"
:value="item.value"
/>
</el-select>
<p>已选:{{ selectedValues }}</p>
</div>
</template>
<script>
export default {
data() {
return {
options: [
{ value: 'option1', label: '选项1' },
{ value: 'option2', label: '选项2' }
],
selectedValues: []
};
}
};
</script>
自定义多选逻辑
如果需要完全自定义多选行为(如点击 div 切换选中状态),可以通过方法手动管理选中状态。
<template>
<div>
<h3>点击选择项目:</h3>
<div
v-for="item in items"
:key="item.id"
@click="toggleSelect(item.id)"
:class="{ selected: selectedItems.includes(item.id) }"
>
{{ item.name }}
</div>
<p>已选:{{ selectedItems }}</p>
</div>
</template>
<script>
export default {
data() {
return {
items: [
{ id: 1, name: '项目A' },
{ id: 2, name: '项目B' }
],
selectedItems: []
};
},
methods: {
toggleSelect(id) {
const index = this.selectedItems.indexOf(id);
if (index === -1) {
this.selectedItems.push(id);
} else {
this.selectedItems.splice(index, 1);
}
}
}
};
</script>
<style>
.selected {
background-color: #f0f0f0;
border: 1px solid #409eff;
}
</style>
注意事项
- 复选框组的
v-model必须绑定到数组,否则无法实现多选。 - 动态生成的选项需确保
:key唯一。 - 使用第三方组件时,需按文档正确配置多选模式(如 Element UI 的
multiple属性)。






