el-select下拉框 添加 el-checkbox 多选框,支持全选、取消全选

el-select下拉框 添加 el-checkbox 多选框,支持全选、取消全选

  • 前言
  • 一、实现思路
  • 二、实现代码
    • 1.模板代码
    • 2. css 样式
    • 3.js 代码
  • DEMO 演示
  • 总结


前言

实现效果预览
el-select下拉框 添加 el-checkbox 多选框,支持全选、取消全选_第1张图片


提示:本内容基于element-ui 组件实现,如果使用其他组件库、可参考下面实现方式的思路

一、实现思路

准备直接使用 el-select 组件的 multiple 属性实现 多选,添加el-checkbox 组件实现全选,以及数据项的选框展示

二、实现代码

1.模板代码

el-select 中加入了全选 el-checkbox,以及在 el-option 中加入了 el-checkbox 控制样式。

<el-select v-model="data" multiple popper-class="select-popover-class">
   	<el-checkbox 
   		:value="selectAll" 
   		:indeterminate="indeterminate" 
   		@change="selectAllHandle">全选el-checkbox>
	<el-option 
       v-for="item in options" 
       :key="item.value" 
       :value="item.value"
       :label="item.label">
       <el-checkbox :value="data.includes(item.value)" :label="item.label">
   el-option>
el-select>

2. css 样式

重点在第二个样式,我们这里只取 el-checkbox 的样式,所以取消事件的触发。

/* 控制全选按钮样式 */
.select-popover-class .el-scrollbar__view > .el-checkbox{
    padding: 5px 20px;
}

/* 取消多选框触发事件 */
.select-popover-class .el-scrollbar__view > li .el-checkbox {
    pointer-events: none;
}

/* 隐藏多选框选中勾选样式 √ */
.select-popover-class .el-scrollbar__view > li::after {
    display: none;
}

3.js 代码

从头到尾只有 data 属性是双向绑定的,其他 包括selectAllindeterminate、以及选项上的el-checkbox是否选中 都是根据data 属性判断计算的。

使用的是vue2.xJavaScript 实现,使用vue3.xTypeScript,参考实现就好。

{
  data: {
    data: [],
    options: [
        {
            label: '选项1',
            value: 1
        },
        {
            label: '选项2',
            value: 2
        },
        {
            label: '选项3',
            value: 3
        }
    ]
  },
  computed: {
      selectAll() {
          if(this.data.length){
              return this.data.length === this.options.length;
          }
          return false;
      },
      indeterminate() {
          if(this.data.length){
              return this.data.length !== this.options.length;
          }
          return false;
      }
  },
  methods: {
      selectAllHandle(bool) {
          this.data = bool ? this.options.map(v => v.value) : [];
      }
  },
}

DEMO 演示

demo中引用了 vueelement-ui 的cdn 资源,可能加载较慢,如果加载不成功自行更换其他可用资源尝试。

多选演示demo


总结

因为整个交互都是使用的el-select 多选模式自带的功能,所以结构还是比较清晰的。

注意: 多选框都是使用 :value="" 绑定数据、无须双向绑定。

以上信息如有问题或疏漏,欢迎指正,谢谢。

你可能感兴趣的:(vue.js,elementui,前端)