uniapp自定义圆形勾选框和全选框

自定义圆形勾选框和全选框

原来用的checkbox

cpp 复制代码
	dataList: [],//数据列表
	allChecked: false,//是否全选
	selectList: [],//选中的id列表
	selectNameList: [],//选中的name列表
cpp 复制代码
	<!--checkbox start -->
	<!--单选-->
	<view class="li" v-for="(item,index) in  dataList" :key="index" @click="btnApprove(item)">
		<checkbox :checked="selectList.length > 0 && selectList.indexOf(item.enrollId) !== -1"
	                    class="w30 h64 lh-54"
	                    @click.stop="btnClickSpeciality(item, '')"
	                    style="transform: scale(0.8) translateY(0px);margin-left:15px;"
	                    />
	</view>
	
	<!--全选-->
	<view class="h70" v-if="dataList.length > 0"></view>
	<view class="bottomStatus" v-if="dataList.length > 0">
		<checkbox :checked="allChecked" @click="handleSelectionChange(!allChecked)" />全选
		
		<view class="refuse">驳回</view>
		<view class="sure">同意</view>
	</view>
	<!--checkbox end -->
cpp 复制代码
	<!--自定义checkbox start -->
	<!--自定义圆形勾选框 单选-->
	<view v-if="curValue==0" style="margin-right: 15px;">
		<!--已选中-->
		<view class="el-radio__input is-checked" v-if="selectList.length > 0 && selectList.indexOf(item.enrollId) !== -1" @click.stop="btnClickSpeciality(item, '')">
              <text class="iconfont icon-success" style="color: white;"></text>
		</view>
        <!--未选中-->
		<view class="el-radio__input" v-else @click.stop="btnClickSpeciality(item, '')"></view>
	</view>


	<view class="h70" v-if="dataList.length > 0"></view>
    <view class="bottomStatus" v-if="dataList.length > 0">
    <!--自定义圆形勾选框 多选-->
   	 <view style="margin-right: 15px;">
      <!--已选中-->
        <view class="el-radio__input is-checked" v-if="allChecked" @click="handleSelectionChange(!allChecked)">
   	     <text class="iconfont icon-success" style="color: white;"></text>
        </view>
      <!--未选中-->
        <view class="el-radio__input" v-else @click="handleSelectionChange(!allChecked)"></view>
        </view>
        全选
     </view>

     <view class="refuse" @click="btnAllRefuse">驳回</view>
     <view class="sure" @click="btnSure">同意</view>
    </view>
	<!--自定义checkbox end -->
cpp 复制代码
  // 点击单选
    btnClickSpeciality(row) {
      let index = this.selectList.indexOf(row.enrollId);
      if (index !== -1) {
        this.selectList.splice(index, 1);
        this.selectNameList.splice(index, 1);
      } else {
        this.selectList.push(row.enrollId);
        this.selectNameList.push(row.studentName)
      }
      this.checkAll();
    },
	 // 全选
    checkAll() {
      if (this.dataList && this.dataList.length > 0) {
        let checkList = this.dataList.filter(a => this.selectList.find(b => a.enrollId == b));
        console.log("checkList===", checkList);

        if (this.dataList.length == checkList.length) {
          this.allChecked = true;
        } else {
          this.allChecked = false;
        }

      } else {
        this.allChecked = false;
      }
    },
     // 点击全选
    handleSelectionChange(e) {
      if (e) {
        let list = this.dataList.filter((a) => !this.selectList.find(b => a.enrollId == b));

        list.map(row => {
          this.btnClickSpeciality(row);
        })
      } else {
        let list = this.dataList.filter((a) => this.selectList.find(b => a.enrollId == b));
        list.map(row => {
          this.btnClickSpeciality(row);
        })
      }
    },
相关推荐
Fly-ping6 小时前
【前端】JavaScript 的事件循环 (Event Loop)
开发语言·前端·javascript
在逃的吗喽7 小时前
黑马头条项目详解
前端·javascript·ajax
JHCan3337 小时前
一个没有手动加分号引发的bug
前端·javascript·bug
天涯学馆8 小时前
为什么越来越多开发者偷偷用上了 Svelte?
前端·javascript·svelte
拾光拾趣录9 小时前
为什么浏览器那条“假进度”救不了我们?
前端·javascript·浏览器
香菜狗9 小时前
vue3响应式数据(ref,reactive)详解
前端·javascript·vue.js
油丶酸萝卜别吃9 小时前
SSE与Websocket有什么区别?
前端·javascript·网络·网络协议
27669582929 小时前
拼多多小程序 anti_content 分析
java·javascript·python·node·拼多多·anti-content·anti_content
顽疲9 小时前
从零用java实现 小红书 springboot vue uniapp(14) 集成阿里云短信验证码
java·vue.js·spring boot·阿里云·uni-app
The_era_achievs_hero10 小时前
uni-appDay02
javascript·vue.js·微信小程序·uni-app