Question

As you all know since it is one of the most asked topic on SO, I am having problems with rounding errors (it isn't actually errors, I am well aware). Instead of explaining my point, I'll give an example of what possible numbers I have and which input I want to be able to obtain:

Let's say

var a = 15 * 1e-9;
alert(a)

outputs

1.5000000000000002e-8

I want to be able to obtain 1.5e-8 instead, but I cannot just multiply by 10e8, round and divide by 10e8 because I don't know if it will be e-8 or e-45 or anything else.

So basically I want to be able to obtain the 1.5000002 part, apply toFixed(3) and put back the exponent part.

I could convert into a string and parse but it just doesn't seem right...

Any idea ?


(I apologize in advance if you feel this is one of many duplicates, but I could not find a similar question, only related ones)

Gael

Was it helpful?

Solution

You can use the toPrecision method:

var a = 15 * 1e-9;
a.toPrecision(2); // "1.5e-8"

OTHER TIPS

If you're doing scientific work and need to round with significant figures in mind: Rounding to an arbitrary number of significant digits

Licensed under: CC-BY-SA with attribution
Not affiliated with StackOverflow
scroll top