ParseFloat function in JavaScript

孤街醉人 提交于 2019-12-03 11:15:45
17 of 26

The Javascript Number class has a toFixed() function that will get you what you want.

So you could do parseFloat("1.0019999").toFixed(3) and that would give you 1.002.

The parameter (3 in this case) is the number of digits to show after the decimal point

0.002 cannot be accurately represented as a base 2 number. Similar to the way that 1/3 can't be represented in base 10.

1/3 = 0.33333... recuring. To represent the number accurately in base 10, you would need an infinite number of decimal digits.

0.002 is a number that can be accurately represented in base 10 (as we see here), but not in base 2, as used by computers. To represent this number accurately, would take an infinite number of binary digits.

This is a known problem: see accuraty problem and the minimisation of the accuracy problem: minimisation

The javascript methods Number.toFixed() and Number.toPrecision() can help here, but they return a String. A possible solution is as follows:

var x = parseFloat(parseFloat("1.0019999999").toPrecision(3));

If you want to a quick fix you can round to the nearest thousandth

Math.round((1.001+0.001)*1000)/1000

易学教程内所有资源均来自网络或用户发布的内容,如有违反法律规定的内容欢迎反馈
该文章没有解决你所遇到的问题?点击提问,说说你的问题,让更多的人一起探讨吧!