浮点数的最高精度是17位小数,但在进行算术运算时其精确度远远不如整数,0.1+0.2的结果不是0.3,而是0.30000000000000004。这个小小的舍入误差会导致无法测定特定的浮点数值,如if (0.1 + 0.2 == 0.3)得到的是false。


JS的浮点数值必须包含一个小数点,且小数点后面必须至少有一位数字,虽然小数点前面可以没有整数,但不推荐这种写法。

由于保存浮点数值的空间是保存整数数值的两倍,因此js会不失时机地将浮点数值转换为整数值。显然,若小数点后面没有跟任何数字,如1.,则这个数值可以作为整数值来保存;同样,若浮点数值本身表示的就是一个整数,如1.0,则该值也会转换为整数。

对于那些极大或极小的数值,可以用e表示法(科学计数法)表示的浮点数值表示。


本文转载:CSDN博客