手工实现iview的CheckBoxGroup组件功能

官方的组件样式无法满足项目需求,所以手动实现了该组件的功能

在formData.typeIDList中存储选中的

html部分:

 <span v-for="(item,index) in productList" :key="item.id">
	<span v-if="(index+1)%6!==0" >
			<Checkbox  :value="isChoiced(item.id)"  :label="item.id" @on-change="v=>{handleCheckBoxChange(v,item.id)}">
					<span >{{item.type}}</span>
		   </Checkbox>
   </span>
   <span v-if="(index+1)%6===0" >
			<Checkbox   :value="isChoiced(item.id)" :label="item.id" @on-change="v=>{handleCheckBoxChange(v,item.id)}">
					<span >{{item.type}}</span>
		   </Checkbox>
	   <br/>
   </span>
</span>

js部分:

isChoiced (typeId) {
  for (let i = 0; i < this.formData.typeIDList.length; i++) {
	  if (this.formData.typeIDList[i] === typeId) {
		  return true;
	  }
  }
  return false;
},


handleCheckBoxChange (v, typeId) {
		  // alert(v);
		  if (v) {
			  this.formData.typeIDList.push(typeId);
		  } else {
			  for (let i = 0; i < this.formData.typeIDList.length; i++) {
				  if (this.formData.typeIDList[i] === typeId) {
					  this.formData.typeIDList.splice(i, 1);
					  break;
				  }
			  }
		  }
		  this.$refs.editForm.validateField('typeIDList');
		  // alert(this.formData.typeIDList);
	  },

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值