JS小数运算丢失精度计算错误等解决方案
2017-02-28 14:43
746 查看
//给Number类型增加一个div方法,调用起来更加方便。 Number.prototype.div = function (arg){ return accDiv(this, arg); }; //乘法函数,用来得到精确的乘法结果 //说明:javascript的乘法结果会有误差,在两个浮点数相乘的时候会比较明显。这个函数返回较为精确的乘法结果。 //调用:accMul(arg1,arg2) //返回值:arg1乘以arg2的精确结果 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); } //给Number类型增加一个mul方法,调用起来更加方便。 Number.prototype.mul = function (arg){ return accMul(arg, this); }; //加法函数,用来得到精确的加法结果 //说明:javascript的加法结果会有误差,在两个浮点数相加的时候会比较明显。这个函数返回较为精确的加法结果。 //调用:accAdd(arg1,arg2) //返回值:arg1加上arg2的精确结果 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; } //给Number类型增加一个add方法,调用起来更加方便。 Number.prototype.add = function (arg){ return accAdd(arg,this); } //减法函数 function accSub(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)); //last modify by deeka //动态控制精度长度 n=(r1>=r2)?r1:r2; return ((arg2*m-arg1*m)/m).toFixed(n); } ///给number类增加一个sub方法,调用起来更加方便 Number.prototype.sub = function (arg){ return accSub(arg,this); }
相关文章推荐
- javascript(js)小数精度丢失的解决方案
- 如何在js中精确除法计算并保留两位小数(不丢失精度)java针对于BigDecimal类型
- js中小数运算精度丢失问题
- javascript(js)小数精度丢失的解决方案
- JS 浮点数运算丢失精度解决方案
- JS 浮点运算精度解决办法 (把小数转换为整数进行计算【但是不能超过js的整数上限】)
- JS浮点类型运算精度丢失问题解决办法
- js中保证小数运算精度的解决
- js,java小数计算精度问题
- JavaScript小数计算精度丢失问题解决方案
- JS小数运算精度问题
- js小数运算精度问题,js浮点数运算时出现精度问题
- JS 浮点数四则运算精度丢失
- JS浮点类型运算精度丢失问题解决办法
- js浮点运算精度丢失的解决办法
- js 浮点小数计算精度问题 parseFloat 精度问题
- 关于js语法(运算中出现无限大的问题)本身的错误的解决方案
- 数学运算高级工具bc:小数精度;进制转换;计算平方及平方根
- js计算出现多位小数-Javascript 浮点运算问题分析与解决
- java中float/double计算丢失精度解决方案