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

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

1、原代码说明

js 复制代码
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

但实际的十进制结果如下图所示,为1726009600

这个问题为原代码逻辑问题,在函数中已经过滤了00格式的值。因此根据需要确定是否需要移除该代码。(若函数引用次数多,直接移除可能导致其他问题)

js 复制代码
const newArray = arrayValue.filter(item => String(item) !== '00' || String(item) !== '0')

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

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

js 复制代码
/**
 * 将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}`)
}

使用最新函数处理以上两个例子结果如下。

相关推荐
五月君_1 分钟前
炸裂!Claude Opus 4.6 与 GPT-5.3 同日发布:前端人的“自动驾驶“时刻到了?
前端·gpt
Mr Xu_6 分钟前
前端开发中CSS代码的优化与复用:从公共样式提取到CSS变量的最佳实践
前端·css
鹏北海-RemHusband42 分钟前
从零到一:基于 micro-app 的企业级微前端模板完整实现指南
前端·微服务·架构
LYFlied43 分钟前
AI大时代下前端跨端解决方案的现状与演进路径
前端·人工智能
光影少年1 小时前
AI 前端 / 高级前端
前端·人工智能·状态模式
一位搞嵌入式的 genius1 小时前
深入 JavaScript 函数式编程:从基础到实战(含面试题解析)
前端·javascript·函数式
anOnion1 小时前
构建无障碍组件之Alert Dialog Pattern
前端·html·交互设计
choke2331 小时前
[特殊字符] Python 文件与路径操作
java·前端·javascript
云飞云共享云桌面1 小时前
高性能图形工作站的资源如何共享给10个SolidWorks研发设计用
linux·运维·服务器·前端·网络·数据库·人工智能
Deng9452013141 小时前
Vue + Flask 前后端分离项目实战:从零搭建一个完整博客系统
前端·vue.js·flask