vue element el-select 下拉多选带有全选框

本文介绍了如何在Vue中使用Element UI的select组件创建一个支持多选并配备全选框的功能,适合前端开发者学习和实践。

vue element el-select 下拉多选带有全选框

在这里插入图片描述

<template>
  <div>
    <el-form ref="form" label-width="80px" :model="test">
      <el-row :gutter="20">
        <el-col :span="6">
          <el-form-item label="核算中心:">
            <el-select
              v-model="test.code"
              multiple
              collapse-tags
              v-bind="$attrs"
              v-on="$listeners"
            >
              <span class="check_left">全选</span>
              <el-checkbox
                v-model="check"
                class="m-l-20"
                :indeterminate="test.code.length !== options.length"
                @change="selectAll"
              >
              </el-checkbox>
              <span :class="test.code.length ? 'check_right rights' : 'check_right1 rights'"
                >勾选选项</span
              >
              <el-option
                v-for="item in options"
                :key="item.value"
                :label="item.label"
                :value="item.value"
              />
            </el-select>
          </el-form-item>
        </el-col>
      </el-row>
    </el-form>
  </div>
</template>

<script>
export default {
  name: "",
  components: {},
  data() {
    return {
      test: {
        code: ["选项1", "选项2", "选项3", "选项4", "选项5"],
      },
      options: [
        { value: "选项1", label: "黄金糕" },
        { value: "选项2", label: "双皮奶" },
        { value: "选项3", label: "蚵仔煎" },
        { value: "选项4", label: "龙须面" },
        { value: "选项5", label: "北京烤鸭" },
      ],
    };
  },
  computed: {
    check: {
      get() {
        if (this.test.code.length === this.options.length) {
          return true;
        }
        return false;
      },
      set() {},
    },
  },
  mounted() {},
  methods: {
    selectAll(checked) {
      if (checked) {
        this.test.code = this.options.map((d) => d.value);
      } else {
        this.test.code = [];
      }
    },
  },
};
</script>
<style scoped>
.check_left {
  font-size: 14px;
  padding-left: 5px;
  padding-right: 20px;
  color: #409eff;
}
.rights {
  font-size: 12px;
  padding-left: 5px;
}
.check_right {
  color: #409eff;
}
</style>

评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值