news 2026/2/12 17:33:28

大小仅 1KB!超级好用!计算无敌!

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
大小仅 1KB!超级好用!计算无敌!

大小仅 1KB!超级好用!计算无敌!

js 原生的数字计算是一个令人头痛的问题,最常见的就是浮点数精度丢失。

// 1. 加减运算0.1+0.2// 结果:0.30000000000000004(预期 0.3)0.7-0.1// 结果:0.6000000000000001(预期 0.6)// 2. 乘法精度偏移0.1*0.2// 结果:0.020000000000000004(预期 0.02)3*0.3// 结果:0.8999999999999999(预期 0.9)// 3. 除法结果异常0.3/0.1// 结果:2.9999999999999996(预期 3)1.2/0.2// 结果:5.999999999999999(预期 6)

在金额计算的场景中出现这种问题是很危险的,例如「0.1 元 + .2 元」本应等于 0.3 元,原生计算却会得出 0.30000000000000004 元,直接导致金额显示错误或支付逻辑异常。

不少人会用toFixed四舍五入,保留 2 位小数来格式化数字,它本质上是字符串格式化工具,而非精度修复工具,而且还会带来新的精度问题 ——toFixed的四舍五入规则是 “银行家舍入法”,无法解决底层计算的精度误差。

// 问题1. 四舍五入规则不符合预期1.005.toFixed(2);// 结果:"1.00"(预期 "1.01")2.005.toFixed(2);// 结果:"2.00"(同样问题)1.235.toFixed(2);// 结果:"1.23"(预期 "1.24")// 问题2. 无法修复底层计算误差constsum=0.1+0.2;// 0.30000000000000004sum.toFixed(2);// 结果:"0.30"(表面正确,但误差仍存在,后续再运算仍然有问题)sum.toFixed(10);// 结果:"0.3000000000"(仅隐藏误差,未消除)

number-precision能解决这些问题。

number-precision 的优势在哪?

  • 轻量化,大小仅 1kb
  • API 极简化,只有加减乘除和四舍五入
  • 专注精度问题,无额外心智负担
  • 兼容性好,无额外依赖

适用场景

  • 中小型项目、仅需解决基础加减乘除精度问题的场景(如电商、金融类简单计算)
  • 对包体积敏感的前端项目。

如何使用?

pnpminstallnumber-precision
importNPfrom'number-precision'NP.strip(0.09999999999999998);// = 0.1NP.plus(0.1,0.2);//加法计算 = 0.3, not 0.30000000000000004NP.plus(2.3,2.4);//加法计算 = 4.7, not 4.699999999999999NP.minus(1.0,0.9);//减法计算 = 0.1, not 0.09999999999999998NP.times(3,0.3);//乘法计算 = 0.9, not 0.8999999999999999NP.times(0.362,100);//乘法法计算 = 36.2, not 36.199999999999996NP.divide(1.21,1.1);//除法计算 = 1.1, not 1.0999999999999999NP.round(0.105,2);//四舍五入,保留2位小数 = 0.11, not 0.1

混合的计算:

importNPfrom'number-precision'// (0.8-0.5)x1000,保留2位小数NP.round(NP.times(NP.minus(0.8,0.5),1000),2)// 计算股票收益率NP.round(NP.times(NP.divide(NP.minus(+price,+cost),+cost),100),2)

更复杂的计算场景用什么

number-precision有短小精悍的优势在,基本的运算都能拿捏,但那些要求更高的计算场景用什么库呢?

特点场景库体积优势劣势适用场景
toFixed内置方法,仅用于数字格式化,不解决底层精度问题0无需额外引入,使用便捷无法修复计算误差,四舍五入规则非标准非精确场景的临时格式化
number-precision轻量化,提供加减乘除、四舍五入基础功能,无多余1KB体积极小,API 极简,学习成本低不支持超大整数,无复杂数学运算电商价格计算、表单数字校验
big.js专注十进制浮点数运算,API 简洁,默认精度可配置6KB平衡体积与功能,兼容性好功能少于 decimal.js中小型项目精确计算、数据统计
decimal.js功能全面,支持高精度控制、大数字处理、进制转换、三角函数等,可自定义精度配置32KB精度极高,功能覆盖全,灵活性强体积较大,API 较复杂金融核心计算、科学计算
math.js全能型数学库,支持表达式解析、矩阵运算、单位转换等复杂数学能力160KB综合数学能力强,场景覆盖广体积庞大,性能开销高数据可视化、工程计算
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/2/5 12:17:50

零基础部署Wan2.2-T2V-A14B:本地化视频生成全指南

零基础部署Wan2.2-T2V-A14B:本地化视频生成全指南 你有没有试过在脑中构思一个画面:“深夜的东京街头,霓虹灯在湿漉漉的地面上反射出斑斓光影,穿皮衣的赛博战士缓缓走过,身后是全息广告牌闪烁着未知语言”——然后希望…

作者头像 李华
网站建设 2026/2/7 13:47:40

EmotiVoice社区版与商业版功能对比指南

EmotiVoice社区版与商业版功能对比指南 在AI语音合成技术飞速发展的今天,如何让机器“说话”不再冰冷机械,而是充满情感、富有表现力,已成为语音交互产品竞争的核心。EmotiVoice 正是在这一背景下脱颖而出的开源项目——它不仅能够生成自然流…

作者头像 李华
网站建设 2026/2/11 6:50:00

python bert_score使用本地模型的方法

1. 背景 bert_score是一个用于评估文本生成质量的Python库,基于预训练的BERT模型计算参考文本与生成文本之间的语义相似度。它通过比较两个文本的BERT嵌入向量来评估它们的匹配程度,比传统的n-gram匹配方法(如BLEU、ROUGE)更能捕…

作者头像 李华
网站建设 2026/2/11 2:29:24

TCP/IP协议

一、什么是TCP/IP协议?指能够在多个不同网络间实现信息传输的协议簇。TCP/IP协议不仅仅指的是TCP 和IP两个协议,而是指一个由FTP、SMTP、TCP、UDP、IP等协议构成的协议簇, 只是因为在TCP/IP协议中TCP协议和IP协议最具代表性,所以被…

作者头像 李华
网站建设 2026/2/9 9:13:07

Qwen-Image-Edit-2509显存优化实战

Qwen-Image-Edit-2509显存优化实战 ——让专业级图像编辑在单卡上“轻装上阵” 电商主图一键换色、社媒配图秒级改稿,早已不是新鲜事。真正让人头疼的,是背后那个动不动就爆显存的AI模型:刚加载完Qwen-Image-Edit-2509,还没开始推…

作者头像 李华