在项目中遇到这样一个奇怪的问题:
在计算 8888000000*0.2*1.1的时候,计算机得到的结果是 195536000.000003
但是实际上计算并没有后面的小数,这时候我们就产生了精度丢失问题,
解决方法:
num是我们要处理的
this.kzbzj = parseFloat(num.toPrecision(12))
就可以得到正确的结果
数据展示类
当你拿到 1.4000000000000001 这样的数据要展示时,建议使用 toPrecision 凑整并 parseFloat 转成数字后再显示,如下:
parseFloat(1.4000000000000001.toPrecision(12)) === 1.4 // true
封装成方法就是:
function strip(num, precision = 12) {
return +parseFloat(num.toPrecision(precision));
}
为什么选择 12 做为默认精度?
这是一个经验的选择,一般选12就能解决掉大部分0001和0009问题,而且大部分情况下也够用了,如果你需要更精确可以调高。