当前位置: 首页 > article >正文

uniapp解析蓝牙设备响应数据bug

本文章为了解决《uniapp 与蓝牙设备收发指令详细步骤(完整项目版)》中第十步的Array 解析成 number函数bug

1、原代码说明

function array16_to_number(arrayValue) {
	const newArray = arrayValue.filter(item => String(item) !== '00' || String(item) !== '0')
	const _number16 = newArray.map(hex => parseInt(hex, 16).toString(16)).join('')
	return parseInt(`0x${_number16}`)
}

该函数用于将16进制的数组转成10进制数字。
在这里插入图片描述

2、Bug场景:日期

对于大多数场景的转换都能正常实现,但是对于日期场景则会出现异常,并且并不是每次都会出现解析错误。

2.1 例子1

在这里插入图片描述
经过原函数转换结果为107925822

但是!!!,如下图十六进制的内容660ed13e,其十进制的结果应该为1712247102
在这里插入图片描述

结论: 由于parseInt函数解析的时候会忽略字符串前面的0。

2.2 例子2

已数组['66','e0','d1','00']为例,经过原函数的转换得到结果如下图,为107875600
图1
但实际的十进制结果如下图所示,为1726009600
在这里插入图片描述
这个问题为原代码逻辑问题,在函数中已经过滤了00格式的值。因此根据需要确定是否需要移除该代码。(若函数引用次数多,直接移除可能导致其他问题)

const newArray = arrayValue.filter(item => String(item) !== '00' || String(item) !== '0')

3、最新代码说明(推荐方式)

由于array16_to_number()需要处理的数组中确实需要移除00元素的值,因此采用新增参数的方式 优化函数,然后在解析日期的位置进行特殊处理即可。

/**
 * 将16进制数组转换成数字

 * @param {Object} arrayValue 16进制的数组
 * @param {Object} notFilter 是否保留数组中值为 00 的元素;可以传入任何值,建议传入 true,否则不需要传值
 */
function array16_to_number(arrayValue, notFilter) {
	let newArray = arrayValue.filter(item => String(item) !== '00' || String(item) !== '0')
	// 有些部分功能不需要将 00 的元素移除
	if(notFilter) newArray = arrayValue
	
	const _number16 = newArray.map(hex => {
		let t_str_numer = parseInt(hex, 16).toString(16)
		// 解决零开头的值会被解析错误,例如:hex=0a,最后会被解析为a
		// 将长度不为2的内容,使用0在字符串前面进行填充
		return t_str_numer.length < 2 ? t_str_numer.padStart(2, '0') : t_str_numer
	}).join('')
	return parseInt(`0x${_number16}`)
}

使用最新函数处理以上两个例子结果如下。
在这里插入图片描述
在这里插入图片描述


http://www.kler.cn/a/394749.html

相关文章:

  • 行业类别-金融科技-子类别区块链技术-细分类别智能合约-应用场景供应链金融课题
  • 力扣-Mysql-3308- 寻找表现最佳的司机(中等)
  • 卷积神经网络之Yolo详解
  • Prometheus面试内容整理-Exporters
  • Dolby TrueHD和Dolby Digital Plus (E-AC-3)编码介绍
  • mysql 配置文件 my.cnf 增加 lower_case_table_names = 1 服务启动不了的原因
  • 3588 yolov8 onnx 量化转 rknn 并运行
  • spark的学习-06
  • k8s 1.28.2 集群部署 docker registry 接入 MinIO 存储
  • leveldb存储token的简单实现
  • 数据结构-布隆过滤器和可逆布隆过滤器
  • vue中 通过cropperjs 实现图片裁剪
  • 开源项目低代码表单设计器FcDesigner扩展右侧组件的配置规则
  • Spring Cloud Gateway(分发请求)
  • 边缘提取函数 [OPENCV--2]
  • 数据结构的时间复杂度和空间复杂度
  • 推荐一款CFD/CAE可视化分析软件:Tecplot 360 EX
  • Unity 中使用 C# 对 Vector2 向量朝向进行顺时针排序及复杂排序场景处理
  • Leetcode 存在重复元素II
  • 深入探索:Scrapy深度爬取策略与实践
  • Linux(文件特殊属性 + FACL 图片+大白话)
  • 机器学习基础04
  • Java项目实战II基于微信小程序的实习记录(开发文档+数据库+源码)
  • Unity3D 制作MMORPG 3D地图编辑器详解
  • FBX福币交易所恒指收跌1.96% 半导体股继续回调
  • SpringBoot整合Freemarker(四)