前端基础学习-select下拉框实现多选、全选

基础效果

其实在element ui里面已经实现了el-select的多选效果
在这里插入图片描述

主要是multiple属性,另外collapse-tags可以将他们合并成一段文字

但是这样的效果做不到可以全选

全选效果

在这里插入图片描述
在这里插入图片描述
下面是代码

页面部分

		<el-form-item label="可全选下拉框" prop="apply">
            <el-select multiple collapse-tags v-model="ruleForm.apply" @change="changeSelect" placeholder="请选择应用" style="width:100%">
              <el-checkbox v-model="allCheck" @change="selectAll" style="margin-left:10px;padding:5px 0">全选</el-checkbox>
              <el-option
                v-for="(item, index) in appOptions"
                :label="item.label"
                :value="item.code"
                :key="index"
              />
            </el-select>
          </el-form-item>

页面部分主要是添加了一个checkbox用于全选
相关初值

      appOptions: [
        { code: 'No1', value: '01' },
        { code: 'No2', value: '02' },
        { code: 'No3', value: '03' },
        { code: 'No4', value: '04' },
        { code: 'No5', value: '05' }
      ],
      allCheck: false,
      ruleForm: {
      	apply: [],
      }

相关方法

    /** 下拉框全选 */
    selectAll () {
      this.ruleForm.apply = []
      if (this.allCheck) {
        let tmpArr = []
        this.appOptions.forEach((item) => {
          tmpArr.push(item.code)
        })
        this.ruleForm.apply = tmpArr
      } else {
        this.ruleForm.apply = []
      }
    },
    /** 切换全选状态 */
    changeSelect (val) {
      if (val.length === this.appOptions.length) {
        this.allCheck = true
      } else {
        this.allCheck = false
      }
    }
  }

通过切换checkbox的allcheck将选项推入数组然后进行赋值
select绑定change方法,通过选中的选项长度是否与默认长度一致判断是否进行了全选,实现效果

  • 1
    点赞
  • 19
    收藏
    觉得还不错? 一键收藏
  • 2
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值