# toFixed or not toFixed, that is the question.. to rounding a number in Javascript “I could put a cactus on the top of this and sell it to hipsters”

freeCodeCamp has made me ask a grand number of questions about javascript and one of the more recent ones was “so how the %^@\$ do I reduce the number of
^#\$%ing decimal places in a this \$@#\$ing number?!?!” (this question came about just after realising that js thinks that 0.1 + 0.2 equals 0.3000000000000004.)

And as we are talking about Javascript, one question can only ever lead to another, this time being “so do you want a string or a number in response?”

“I want a string response!” (the toFixed() method)

Ok then, this is probably the easiest way of reducing a number to a fixed number of decimal places. You simply add the toFixed() method to your variable with the desired amount of decimal places as the parameter and bob is your uncle.

• //create a variable ‘x’ with 3 decimal places
• var x = 3.146;
• //create a new variable ‘y’ with the toFixed() method with 2 as a parameter to reduce the number to 2 decimal places
• var y = x.toFixed(2);
• //call the y variable
• console.log(y);
• ‘3.15’

“I want a number response!” (the Math.round function)

Then let’s get to it, this is a simple and easy way of rounding a number with decimals to the nearest whole number. You just need to call the Math.round() function with your desired number/variable as the parameter.

• //create a variable ‘x’ with 3 decimal places
• var x = 3.146;
• //create a new variable ‘y’ with the Math.round() function and the variable ’x’ as the parameter
• var y = Math.round(x);
• //call the y variable
• console.log(y);
• 3

“But I need to create a number with 2 decimal places” I hear myself saying time and time again whilst chewing my entire fingernail off. Fear not! There is back way to countering Math.round’s rather depraved need to cut the number’s entire tail off, and it involves just a simple bit of math.

• //create a variable ‘x’ with 3 decimal places
• var x = 3.146;
• //create a new variable ‘y’ with the Math.round() function and the variable ’x’  times 100  then divided by 100 as the parameter, shifting the decimal place back a couple of spots.
• var y = Math.round(x * 100) / 100;
• //call the y variable
• console.log(y);
• 3.15

So there you have it, a couple of ways to round a number down and a great way to solve the Javascript issue with binary and floating point numbers. If there are any errors in this post, apologies, I’m still learning and I find that writing about this stuff as I go helps reinforce it. Any questions about the subject are more than welcome but will most likely be reposted as a question on the StackOverflow website by yours truly.

Extra Time!

If you want to use the toFixed method and still have the result as a number, then just convert it via the parseInt() function post toFixed() conversion as seen below.

• //create a variable ‘x’ with 3 decimal places
• var x = 3.146;
• //create a new variable ‘y’ with the toFixed() method with 2 as a parameter to reduce the number to 2 decimal places
• var y = x.toFixed(2);
• //query the type of y variable
• console.log(typeof y);
• string
• //create a new variable ‘z’ with the parseInt() function and the variable ’z’ as the parameter
• y = parseInt(y);
• //query the type of z variable
• console.log(typeof y);
• number