js计算浮点数出现小数;解决js计算小数问题;js数组相加出现小数;

js计算浮点数出现小数;解决js计算小数问题;js数组相加出现小数;,第1张

js计算浮点数出现小数;解决js计算小数问题;js数组相加出现小数;

原博1 原博2

方案1和方案2都是有效的

情景: 在计算浮点数时候,出现多余小数。
例如: 1.11 + 1 = 2.1100000000000003

为什么计算小数会出现误差?
浮点数值的最高进度是17位小数,但在进行运算的时候其精确度却远远不如整数;整数在进行运算的时候都会转成10进制; 而Java和Javascript中计算小数运算时,都会先将十进制的小数换算到对应的二进制,一部分小数并不能完整的换算为二进制,这里就出现了第一次的误差。待小数都换算为二进制后,再进行二进制间的运算,得到二进制结果。然后再将二进制结果换算为十进制,这里通常会出现第二次的误差。

方案1:简单的js加法和减法:
//加法
Math.round((parseFloat(num1) + parseFloat(num2))*100)/100

//减法
Math.round((parseFloat(num1) - parseFloat(num2))*100)/100
方案2:复杂的加减乘除运算封装:

以下代码可以直接复制使用

有效的话请点赞评论下,让更多的朋友能够看到解决问题!