js加减乘除精度丢失问题解决
更新时间:2023年09月15日 08:25:21 作者:咸鱼起码是条鱼
计算机的二进制实现和位数限制有些数无法有限表示,就会产生精度丢失问题,本文主要介绍了js加减乘除精度丢失问题解决,具有一定的参考价值,感兴趣的可以了解一下
公共类, 将科学计数法的数字转为字符串(以下加减乘除依赖该方法)
var toNonExponential = (num)=> { if(num == null) { return num; } if(typeof num == "number") { var m = num.toExponential().match(/\d(?:\.(\d*))?e([+-]\d+)/); return num.toFixed(Math.max(0, (m[1] || '').length - m[2])); }else { return num; } }
乘(以下加减除依赖该方法)
var floatMultiply = (arg1, arg2) => { arg1 = Number(arg1); arg2 = Number(arg2); if ((!arg1 && arg1!==0) || (!arg2 && arg2!==0)) { return null; } arg1 = toNonExponential(arg1); arg2 = toNonExponential(arg2); var n1, n2; var r1, r2; // 小数位数 try { r1 = arg1.toString().split(".")[1].length; } catch (e) { r1 = 0; } try { r2 = arg2.toString().split(".")[1].length; } catch (e) { r2 = 0; } n1 = Number(arg1.toString().replace(".", "")); n2 = Number(arg2.toString().replace(".", "")); return n1 * n2 / Math.pow(10, r1 + r2); }
除
var floatDivide = (arg1, arg2) => { arg1 = Number(arg1); arg2 = Number(arg2); if (!arg2) { return null; } if (!arg1 && arg1!==0) { return null; }else if(arg1===0) { return 0; } arg1 = toNonExponential(arg1); arg2 = toNonExponential(arg2); var n1, n2; var r1, r2; // 小数位数 try { r1 = arg1.toString().split(".")[1].length; } catch (e) { r1 = 0; } try { r2 = arg2.toString().split(".")[1].length; } catch (e) { r2 = 0; } n1 = Number(arg1.toString().replace(".", "")); n2 = Number(arg2.toString().replace(".", "")); return floatMultiply((n1 / n2), Math.pow(10, r2 - r1)); }
加
var floatAdd = (arg1, arg2) => { arg1 = Number(arg1) || 0; arg2 = Number(arg2) || 0; arg1 = toNonExponential(arg1); arg2 = toNonExponential(arg2); var r1, r2, m; try { r1 = arg1.toString().split(".")[1].length; } catch (e) { r1 = 0; } try { r2 = arg2.toString().split(".")[1].length; } catch (e) { r2 = 0; } m = Math.pow(10, Math.max(r1, r2)); return (floatMultiply(arg1, m) + floatMultiply(arg2, m)) / m; }
减
var floatSub = (arg1, arg2) => { arg1 = Number(arg1) || 0; arg2 = Number(arg2) || 0; arg1 = toNonExponential(arg1); arg2 = toNonExponential(arg2); var r1, r2, m, n; try { r1 = arg1.toString().split(".")[1].length; } catch (e) { r1 = 0; } try { r2 = arg2.toString().split(".")[1].length; } catch (e) { r2 = 0; } m = Math.pow(10, Math.max(r1, r2)); // 动态控制精度长度 n = (r1 >= r2) ? r1 : r2; return ((floatMultiply(arg1, m) - floatMultiply(arg2, m)) / m).toFixed(n); }
参考:https://blog.csdn.net/ycclydy/article/details/123580326
到此这篇关于js加减乘除精度丢失问题解决的文章就介绍到这了,更多相关js加减乘除精度丢失内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!
相关文章
IE下window.onresize 多次调用与死循环bug处理方法介绍
IE下window.onresize多次调用与死循环bug处理方法介绍。需要的朋友可以过来参考下,希望对大家有所帮助2013-11-11JS动态添加与删除select中的Option对象(示例代码)
本篇文章主要介绍了JS动态添加与删除select中的Option对象(示例代码) 需要的朋友可以过来参考下,希望对大家有所帮助2013-12-12
最新评论