vue element下拉框加全选

在这里插入图片描述

 <el-form-item label="国别" prop="nation_id">
    <el-select v-model="nation_id" clearable multiple filterable placeholder="请选择国别" style="width: 100%;" @change="changeNation">
         <el-checkbox
             v-model="checked"
             @change='selectAll'
             style="margin-left:20px">
             全选
         </el-checkbox>
         <el-option
             v-for="item in nationList"
             :key="item.id"
             :label="item.name"
             :value="item.id"
         >
             <span style="float: left; font-size: 15px;">${ item.name } ${ item.cname }</span>
             <span style="float: left; color: #8492a6; font-size: 15px" v-if="item.flag==1">&nbsp;&nbsp;正单</span>
             <span style="float: left; color: #8492a6; font-size: 15px" v-if="item.flag==2">&nbsp;&nbsp;邮购单</span>
         </el-option>
     </el-select>
 </el-form-item>
 nation_id: [],  //国别
 checked: false,//全选国别
                     
  // 国别全选
  changeNation(val){
      if (val.length === this.nationList.length) {
          this.materialTSCLForm.checked = true
      } else {
          this.materialTSCLForm.checked = false
      }
  },
  selectAll() {
      this.materialTSCLForm.nation_id = []
      if (this.materialTSCLForm.checked) {
          this.nationList.map((item) => {
              this.materialTSCLForm.nation_id.push(item.id)
          })
      } else {
          this.materialTSCLForm.nation_id = []
      }
      this.$emit('changeNation', {val:this.materialTSCLForm.nation_id,index:this.index});
  },
 
  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值