项目场景:
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()
。