JS 浮点数运算丢失精度解决方案
2016-07-12 09:28
302 查看
原文链接:https://www.geek-share.com/detail/2679286880.html
除法 function accDiv(arg1,arg2){ var t1=0,t2=0,r1,r2; try{t1=arg1.toString().split(".")[1].length}catch(e){} try{t2=arg2.toString().split(".")[1].length}catch(e){} with(Math){ r1=Number(arg1.toString().replace(".","")) r2=Number(arg2.toString().replace(".","")) return accMul((r1/r2),pow(10,t2-t1)); } } //乘法 function accMul(arg1,arg2) { var m=0,s1=arg1.toString(),s2=arg2.toString(); try{m+=s1.split(".")[1].length}catch(e){} try{m+=s2.split(".")[1].length}catch(e){} return Number(s1.replace(".",""))*Number(s2.replace(".",""))/Math.pow(10,m) } //加法 function accAdd(arg1,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 (arg1*m+arg2*m)/m } //减法 function Subtr(arg1,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 ((arg1*m-arg2*m)/m).toFixed(n); }
转载于:https://www.cnblogs.com/zouqin/p/5662389.html
相关文章推荐
- JS 浮点数运算丢失精度解决方案
- js浮点运算精度丢失的解决办法
- JS 浮点数四则运算精度丢失
- JS 浮点数四则运算精度丢失问题
- 转(JS中浮点运算精度错误BUG解决方案)
- js浮点运算精度丢失的解决办法
- JS浮点类型运算精度丢失问题解决办法
- JS小数运算丢失精度计算错误等解决方案
- js浮点运算精度丢失问题
- JS浮点类型运算精度丢失问题解决办法
- JS 浮点数四则运算精度丢失问题
- js浮点运算精度丢失的解决办法
- js 浮点运算出现的精度丢失问题
- 一个解决js浮点运算精度的代码
- java浮点类型(float,double)运算精度问题原因附解决方案代码
- 【解决方案】jison解决JS处理后台返回的Long型数据精度丢失
- js小数运算精度问题,js浮点数运算时出现精度问题
- JS 浮点运算精度解决办法 (把小数转换为整数进行计算【但是不能超过js的整数上限】)
- 使用BigDecimal解决java浮点运算丢失精度问题
- JS运算中精度丢失