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>
相关推荐
护国神蛙20 分钟前
给你一个页面如何定时刷新
前端·javascript·浏览器
一直游到海水变蓝丿28 分钟前
el-select下拉框 添加 el-checkbox 多选框
前端·javascript·vue.js
阿奇__1 小时前
element 跨页选中,回显el-table选中数据
前端·vue.js·elementui
谢尔登1 小时前
【React】SWR 和 React Query(TanStack Query)
前端·react.js·前端框架
断竿散人1 小时前
专题一、HTML5基础教程-Viewport属性深入理解:移动端网页的魔法钥匙
前端
3Katrina1 小时前
理解Promise:让异步编程更优雅
前端·javascript
星之金币1 小时前
关于我用Cursor优化了一篇文章:30 分钟学会定制属于你的编程语言
前端·javascript
天外来物1 小时前
实战分享:用CI/CD实现持续部署
前端·nginx·docker
moxiaoran57531 小时前
Spring Cloud Gateway 动态路由实现方案
运维·服务器·前端
市民中心的蟋蟀1 小时前
第十一章 这三个全局状态管理库之间的共性与差异 【上】
前端·javascript·react.js