checkbox实现单选

项目场景:

checkbox实现单选

现阶段不管是原生checkbox还是小程序常见的组件库里面的checkbox在你实现单选的时候
你选择的数据不是根据选择的顺序来进行排列的,而是根据原数据进行排列的,这就导致
我们实现单选的时候不能准确找到我们当时点击的是哪个数据

以下是我实现单选的思路
数据代码思路:

// 当checkbox第一次选中的时候直接赋值
// e.detail.value:选中的数据 checkUnType:保存的选中的数据
	let detailvalue = e.detail.value
	// 如果数据为空直接赋值[]
	if (detailvalue.length == 0) {
		this.checkUnType = []
	} else {
		// 当选中的数据不是空有两种情况 1.当前保存的数据不为空  2.当前保存的数据为空
		// 当前保存的数据不为空,选中的数据与保存的数据比较,一样表示不是当前选中的数据,进行删除 
		if (this.checkUnType.length != 0) {
						detailvalue.forEach((item, index) => {
							this.checkUnType.forEach((it, i) => {
								if (item.split(',')[1] == it) {
									detailvalue.splice(index, 1)
								}
							});
						});
						// 然后保存detailvalue 剩余数据,正常为1个
						this.checkUnType.push(detailvalue[detailvalue.length-1])
					} else {
					// 当前保存的数据为空
					
					}
				}

原因分析:

提示:这里填写问题的分析:

例如:Handler 发送消息有两种方式,分别是 Handler.obtainMessage()Handler.sendMessage(),其中 obtainMessage 方式当数据量过大时,由于 MessageQuene 大小也有限,所以当 message 处理不及时时,会造成先传的数据被覆盖,进而导致数据丢失。


解决方案:

提示:这里填写该问题的具体解决方案:

例如:新建一个 Message 对象,并将读取到的数据存入 Message,然后 mHandler.obtainMessage(READ_DATA, bytes, -1, buffer).sendToTarget();换成 mHandler.sendMessage()

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值