问题描述
javascript 中为何在做减法时,结果中的小数位会增加许多。比如 :351778.8-206233.77 =145545.02999999997
解决方案
这个bug是js固有的,浮点数精度不准,你可以用下面方法来解决,思路是先放大,求和、差、积等运算后再缩小。如://加法函数,用来得到精确的加法结果 //说明: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);}//减法函数,用来得到精确的减法结果//说明:javascript的减法结果会有误差,在两个浮点数相减的时候会比较明显。这个函数返回较为精确的加法结果。//调用:accSub(arg1,arg2) //返回值:arg1减去arg2的精确结果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)); n = (r1 >= r2) ? r1 : r2; return ((arg1 * m - arg2 * m) / m).toFixed(n);}//给Number类型增加一个add方法,调用起来更加方便。Number.prototype.sub = function(arg) { return accSub(arg, this);}
解决方案二:
楼主可以参考这个:http://my.oschina.net/u/658145/blog/103751
解决方案三:
顶楼上,学习了解浮点数,再决定如何使用它,我建议在计算过程中不出现小数,非数值计算,日常的系统基本上可以不出现小数。
解决方案四:
toFixed(num),num为你所需要的精度,会自动四舍五入。
解决方案五:
你可以使用toFixed(n)进行四舍五入var result = 351778.8-206233.77result = result.toFixed(2);
解决方案六:
google "浮点数 圆整误差 IEEE754"