最近在做项目的时候,遇到了有四舍五入保留两位的需求,当时不假思索的直接使用了js原生的toFixed方法,结果问题百出。有以下几点问题:
1.四舍五入并不是真正的四舍五入
这个问题是在测试阶段我们的测试人员提出来的。一开始我也很吃惊,结果待我在控制台试了一些数据之后,我懵逼了,我一直在用的toFixed方法竟然有问题,我竟然糊涂的用它做了很多事!以下是我在chrome上的结果:
|
|
果然有问题,只能网上找资料了,结果又发现同样是上面的一段代码,在IE下又小同大异,以下是IE上的结果:
果然IE才是爸爸。难道是浏览器兼容性问题?兼容性问题难道不应该是出在IE中吗?既然找到问题所在,就好下手。我的办法是把要四舍五入的后一位单独拎出来单独判断。
自己测了几遍,貌似没什么问题,OK~
2.计算机二进制编码导致的精度问题
没过多久,测试又提出来页面报错了~~ 心塞啊,怎么可能报错呢?自己debugger,发现页面中的js进了死循环。很明显问题出在toFixed中回调了toFixed,结果没有走出来,继续debugger,又有了进人的发现。以下是控制台测试:
console.log(2.115 100) // 211.50000000000003
console.log(2.0115 1000) // 2011.4999999999998
能告诉我是在闹哪样?好吧,我猜到了,肯定是计算机的进制问题。既然你一直进入循环,我就手动把你拉出来。
result = (Math.round((parseFloat(result)) * x) + 1) / x;
强制四舍五入取整,不会进死循环了!
以下是全部代码: