Select 组件实现【全选】(基于 Element)

〇、前言

在 Element 中,Select 组件支持单选和多选,但是并没有全选的属性,因此只能通过其事件和属性来实现,本文将实现一个简单的示例。

注意:本文的示例中,通过 leixing1来兼容多控件共享同一方法。

一、两种实现

1.1 通过添加一个 Checkbox 来操作全选(推荐)

  • 大致思路

在全部选项最上边添加一个 Checkbox 复选框,勾选时自动全选,取消勾选自动取消全部已选中项。

再给 Select 添加一个 Change 事件方法,当选中项等于备选列表长度,则自动勾选 Checkbox,否则取消勾选。

  • 实现效果
  • 前端实现代码

    <el-select
    class="select-item uniform-width"
    v-model="formData.leixing1"
    filterable multiple
    clearable @change="changeSelect($event,'leixing1')"
    placeholder="全部类型(多选)"

    复制代码
    <el-checkbox :indeterminate="isIndeterminate_lx" v-model="checked" @change="selectAll('leixing1')" style="padding:5px 0 10px 20px;">全选</el-checkbox>
    <el-option
      v-for="item in leixing1OptionsList"
      :label="item.mingcheng"
      :value="item.bianma"
      :key="item.bianma"
    />
    </el-select>
  • js 代码实现

    <script> export default { name: "Example", data() { return { isIndeterminate:false, isIndeterminate_lx1:false, isIndeterminate_lx2:false, checked:false, checked_lx1:false, checked_lx2:false, formData:[], leixing1OptionsList:[ {mingcheng:"第1项",bianma:"1"}, {mingcheng:"第2项",bianma:"2"}, {mingcheng:"第3项",bianma:"3"}, ], leixing2OptionsList:[], }; }, methods: { changeSelect(val,leixing) { let list=[] let value="" switch (leixing){ // 根据不同的组件对取值进行区分 case "leixing1": list=this.leixing1OptionsList this.checked=this.checked_lx1 break case "leixing2": list=this.leixing2OptionsList this.checked=this.checked_lx2 break } if (this.formData[leixing].length==list.length) { // 全选 this.checked=true this.isIndeterminate=false } else if (this.formData[leixing].length!=list.length && this.formData[leixing].length>0) { this.checked=false this.isIndeterminate=true }else if(this.formData[leixing].length==0){ this.isIndeterminate=false } switch (leixing){ case "leixing1": this.checked_lx1=this.checked this.isIndeterminate_lx1=this.isIndeterminate break case "leixing2": this.checked_lx2=this.checked this.isIndeterminate_lx2=this.isIndeterminate break } }, selectAll(leixing) { let list=[] let value="" switch (leixing){ // 根据不同的组件对取值进行区分 case "leixing1": list=this.leixing1OptionsList this.checked=this.checked_lx1 this.isIndeterminate_lx1=false value="bianma" // 具体的取值属性配置 break case "leixing2": list=this.leixing2OptionsList this.checked=this.checked_lx2 this.isIndeterminate_lx2=false value="key" // 具体的取值属性配置 break } if (this.checked) { // 全选 list.map((item) => { this.formData[leixing].push(item[value]) }) } else { // 取消全选 this.formData[leixing] = []; } }, }, }; </script>

1.2 通过增加一个 Option 选项'全选'来实现

  • 大致思路

手动增加 Select 的第一个选项'全选',通过这个选项的事件,来操作是否全选。

再通过列表的长度和已选中的选项进行比较,相等就自动勾选'全选',否则就取消勾选。

注意:Select 组件的值会包含'全选'这个值,需要在后端进行过滤。

  • 实现效果
  • 前端控件代码

    <el-select
    class="select-item uniform-width"
    v-model="formData.leixing1"
    filterable multiple
    clearable @change="changeSelect($event,'leixing1')"
    placeholder="全部类型(多选)"

    复制代码
    <el-option label='全选' value='全选' @click.native="selectAll('leixing1')" v-if="leixing1OptionsList.length"></el-option>
    <el-option
      v-for="item in leixing1OptionsList"
      :label="item.mingcheng"
      :value="item.bianma"
      :key="item.bianma"
    />
    </el-select>
  • js 代码实现及解释

    <script> export default { name: "Example", data() { return { formData:[], leixing1OptionsList:[ {mingcheng:"第1项",bianma:"1"}, {mingcheng:"第2项",bianma:"2"}, {mingcheng:"第3项",bianma:"3"}, ], leixing2OptionsList:[], }; }, methods: { changeSelect(val,leixing) { let list=[] let value="" switch (leixing){ // 根据不同的组件对取值进行区分 case "leixing1": list=this.leixing1OptionsList break case "leixing2": list=this.leixing2OptionsList break } if (!val.includes('全选') && val.length === list.length) { // 手动选择全部选项后,自动选中'全选' this.formData[leixing].unshift('全选') } else if (val.includes('全选') && (val.length - 1) < list.length) { // 取消选中任一项,同时取消'全选' this.formData[leixing] = this.formData[leixing].filter((item) => { return item !== '全选'}) } }, selectAll(leixing) { let list=[] let value="" switch (leixing){ // 根据不同的组件对取值进行区分 case "leixing1": list=this.leixing1OptionsList value="bianma" // 具体的取值属性配置 break case "leixing2": list=this.leixing2OptionsList value="key" // 具体的取值属性配置 break } if (this.formData[leixing]!=undefined && this.formData[leixing].length < list.length) { // 全选 this.formData[leixing] = ['全选'] // 默认选中'全选'这一项 list.map((item) => { // 将全部选项加入值列表 this.formData[leixing].push(item[value]) }) } else { // 取消全选 this.formData[leixing] = []; } }, }, }; </script>
相关推荐
RFCEO6 分钟前
前端编程 课程十三、:CSS核心基础1:CSS选择器
前端·css·css基础选择器详细教程·css类选择器使用方法·css类选择器命名规范·css后代选择器·精准选中嵌套元素
Amumu1213830 分钟前
Vuex介绍
前端·javascript·vue.js
We་ct31 分钟前
LeetCode 54. 螺旋矩阵:两种解法吃透顺时针遍历逻辑
前端·算法·leetcode·矩阵·typescript
2601_949480061 小时前
【无标题】
开发语言·前端·javascript
css趣多多1 小时前
Vue过滤器
前端·javascript·vue.js
理人综艺好会2 小时前
Web学习之用户认证
前端·学习
We་ct2 小时前
LeetCode 36. 有效的数独:Set实现哈希表最优解
前端·算法·leetcode·typescript·散列表
weixin_395448912 小时前
main.c_cursor_0129
前端·网络·算法
2401_859049083 小时前
git submodule update --init --recursive无法拉取解决
前端·chrome·git
这是个栗子3 小时前
【Vue代码分析】前端动态路由传参与可选参数标记:实现“添加/查看”模式的灵活路由配置
前端·javascript·vue.js