JS浮点数计算精度丢失问题解决方案,目前最好用的方法之一
解决方案:
本质在处理这类问题的时候,基本思路都是通过把浮点数转换为整数来进行计算,然后再将整数的小数点位调整,转换成正常的浮点数得到结果,
但是这种方法还是会有一些问题,接下来可以看看这种方法,简单实用
Math.formatFloat = function (f, digit) { // 解决js精度丢失问题
var m = Math.pow(10, digit);
return Math.round(f * m, 10) / m;
}
console.log(0.7 - 0.6) // 结果 0.09999999999999998
console.log(0.7 + 0.6) // 结果 1.2999999999999998
console.log(Math.formatFloat(0.7 - 0.6,2)) // 0.1
console.log(Math.formatFloat(0.7 + 0.6,2)) // 1.3
调用方法可以为:
需要注意的一点就是,,2是保留小数点后两位,如果小数点位数比较多,请调整保留相应的小数点位数,不然超出小数点位数会四舍五入,同意会有误差
2301_76204793: 太厉害了👍
yyyooi: 我也是 好难受
Chenge218: 不用了,是源码的问题,跟端口没关系,已经解决了
Chenge218: 有没有人知道为什么serve出来的端口显示是3000而不是5000呢,只能加载到100%但是继续不了啊
我有理想.: 已经晚了