I'm doing this:
var refundAmount = parseFloat($('#refundAmount2').val().replace('$',''));
var refundReceived = $('#refundReceived');
var remainderAmount = refundAmount-parseFloat(refundReceived.val().replace('$',''));
alert(parseInt(remainderAmount).toFixed(2));
No matter what I do, the result always ends with 2 decimal places being '.00'. So if the first number is 200.12 and the second is 100.08, it should be alerting me with 100.04 but instead I get 100.00.
Why might this be happening?
I'm doing this:
var refundAmount = parseFloat($('#refundAmount2').val().replace('$',''));
var refundReceived = $('#refundReceived');
var remainderAmount = refundAmount-parseFloat(refundReceived.val().replace('$',''));
alert(parseInt(remainderAmount).toFixed(2));
No matter what I do, the result always ends with 2 decimal places being '.00'. So if the first number is 200.12 and the second is 100.08, it should be alerting me with 100.04 but instead I get 100.00.
Why might this be happening?
Share Improve this question edited Oct 1, 2021 at 20:40 halfer 20.4k19 gold badges109 silver badges202 bronze badges asked Apr 17, 2013 at 15:36 DamienDamien 4,31910 gold badges41 silver badges54 bronze badges 1-
2
parseInt(remainderAmount)
converts the number to an integer and thentoFixed(2)
appends.00
to it. It might be undesired but it's the predictable result. I think you wantalert(parseFloat(remainderAmount.toFixed(2)));
– Ejaz Commented Apr 17, 2013 at 15:39
2 Answers
Reset to default 7You used parseInt
to convert that number to an integer and then used toFixed(2)
to convert it to a number with 2 decimal places. Adding 2 decimal places to an integer will always result in .00
.
Try
alert(remainderAmount.toFixed(2));
See DEMO.
You're getting it as an int with parseInt(), then doing the toFixed(). So you're putting decimal places on an int.