基于elementUI封装的带复选框el-checkbox的下拉多选el-select组件

效果图:

组件:MultipleSelect.vue

<template>
  <el-select v-model="selectValues" v-bind="$attrs" v-on="listeners" multiple placeholder="请选择" style="width: 50%" @change="changeSelect">
    <el-option v-if="options.length" label="全选" value="全选">
      <el-checkbox v-model="isSelectAll" @click.prevent.native>全选</el-checkbox>
    </el-option>
    <el-option v-for="item in options" :key="item[props.value]" :label="item[props.label]" :value="item[props.value]">
      <el-checkbox v-model="item.isCheck" @click.prevent.native>{
   {
   item[props.label]}}</el-checkbox>
    </el-option>
  </el-select>
</template>
 
<script>
export default {
   
  name: "MultipleSelect",
  inheritAttrs: false,// 似乎设不设置都可以
  model: {
   
    prop: "initSelectValues",
    event: "change"
  },
  props: {
   
    initSelectValues: {
   
      type: Array,
      default: () => []
    },
    // 下拉选项
    options: {
   
      type: Array,
      default: () => []
    },
    // 选项键值对
    props: {
   
      type: Object,
      default: () => {
   
        return {
   
          label: "label",
          value: "value"
        }
      }
    }
  },
  data() {
   
    return {
   
      selectValues: [],
      isSelectAll: false
    }
  },
  watch: {
   
    // 监听(全选,全不选以及checkbox是否勾选)
    selectValues: {
   
      handler(arr) {
   
        this.options.forEach(item => {
   
          if (arr.includes(item[this.props.value])) {
   
            item.isCheck = true
          } else {
   
            item.isCheck = false
          }
        })
 
        if (arr.length === this.options.length) {
   
          this.isSelectAll = true
        } else {
   
          this.isSelectAll = false
        }
        // 强制更新(checkbox回显)
        this.$forceUpdate()
      }
    }
  },
  created() {
   
    // 回显
    this.selectValues = this.initSelectValues
  },
  methods: {
   
    changeSelect(val) {
   
      if (val.includes("全选")) {
   
        // 说明已经全选了,所以全不选
        if (val.length > this.options.length) {
   
          this.selectValues = []
        } else {
   
          this.selectValues = this.options.map(item => item[this.props.value])
        }
      }
      this.$emit("change", this.selectValues)
    }
  }
}
</script>
 
<style>
</style>

使用:index.vue

<template>
  <div id="app">
    <MultipleSelect v-model="value" :options="options"></MultipleSelect>
    <el-button @click="confirm">确定</el-button>
  </div>
</template>

<script>
import MultipleSelect from "./components/MultipleSelect"
export default {
   
  name: 'App',
  components: {
   
    MultipleSelect
  },
  data() {
   
    return {
   
      value: [],
      options: [
        {
   
          value: '选项1',
          label: '黄金糕'
        }, {
   
          value: '选项2',
          label: '双皮奶'
        }, {
   
          value: '选项3',
          label: '蚵仔煎'
        }, {
   
          value: '选项4',
          label: '龙须面'
        }, {
   
          value: '选项5',
          label: '北京烤鸭'
        }
      ]
    }
  },
  methods: {
   
    confirm() {
   
      console.log("value", this.value)
    }
  }
}
</script>

<style>

</style>

多选框多选不换行

 /* 输入框超出隐藏,不换行*/
  .el-select__tags {
   
    flex-wrap: nowrap;
    overflow: auto;
  }

  /* 输入框最大宽度*/
   .el-select__tags-text {
   
    max-width: 90px;
  }

最近更新

  1. docker php8.1+nginx base 镜像 dockerfile 配置

    2024-01-12 23:38:02       94 阅读
  2. Could not load dynamic library ‘cudart64_100.dll‘

    2024-01-12 23:38:02       100 阅读
  3. 在Django里面运行非项目文件

    2024-01-12 23:38:02       82 阅读
  4. Python语言-面向对象

    2024-01-12 23:38:02       91 阅读

热门阅读

  1. 70、C++ - 仓库目录结构介绍

    2024-01-12 23:38:02       56 阅读
  2. MyBatis动态SQL语句

    2024-01-12 23:38:02       67 阅读
  3. macos m1如何安装指定版本的redis

    2024-01-12 23:38:02       59 阅读
  4. 【Golang】补码二进制字符串转整型

    2024-01-12 23:38:02       58 阅读
  5. Linux指令(一)

    2024-01-12 23:38:02       54 阅读
  6. 基于人脸识别的智慧校园方案—总述

    2024-01-12 23:38:02       53 阅读
  7. React16源码: React中的update和updateQueue的源码实现

    2024-01-12 23:38:02       53 阅读
  8. WebSocket的11个面试常见知识点

    2024-01-12 23:38:02       53 阅读
  9. 【pycharm】常见问题与解决

    2024-01-12 23:38:02       61 阅读