Currency Math in JavaScript

13,399

Solution 1

var totalLiabilites = '$52.34';
var toalAssets      = '$85.12';
var pattern         = /[^0-9.-]+/g;

var result = parseFloat(toalAssets.replace(pattern, '')) -
             parseFloat(totalLiabilites.replace(pattern, ''));

// result: 32.78

Note: In JavaScript it is recommended1 to handle money as an integer representing the number of cents (8512 instead of 85.12). This is to avoid problems with floating-point arithmetic. 0.1 + 0.2 == 0.3 returns false in JavaScript, but fortunately integer arithmetic in floating point is exact, so decimal representation errors can be avoided by scaling.

You may want to check the following post for further reading on this topic: Is JavaScript’s math broken?

You can always apply the currency-sign formatting when the values are rendered to the browser.


1Douglas Crockford: JavaScript: The Good Parts: Appendix A - Awful Parts (page 105).

Solution 2

parseFloat() won't work because your string begins with a non-number, the dollar sign.

You can simply do a replace to remove the dollar sign, along with a parseFloat to get the value:

totalAssets = parseFloat(totalAssets.replace('$', ''));
totalLiabilities = parseFloat(totalLiabilities.replace('$', ''));

var difference = '$' + (totalAssets - totalLiabilities);

This code replaces your original strings with floats. You could load them into new variables as well. Likewise, difference does not have to have the '$' prepended.

Solution 3

var a = "$20";
var b = "$34";
var c = parseFloat(a.replace(/[^0-9\.]+/g, "")) - parseFloat(b.replace(/[^0-9\.]+/g, ""));
alert(c);
Share:
13,399

Related videos on Youtube

swisstony
Author by

swisstony

Updated on April 17, 2022

Comments

  • swisstony
    swisstony about 2 years

    Can someone please help me out with a JavaScript/jQuery solution for this arithmetic problem:

    I need to subtract one number from the other.

    The problem is that the numbers have a dollar sign (because its money), therefore jQuery is treating them as strings instead of numbers.

    I have created two variables - toalAssets and totalLiabilites. I would like to subtract the latter from the former and place the result into another variable called netWorth.

    Perhaps i need to use parseFloat()?

    But I'm not sure how - This is all a little over my head!

    • DisgruntledGoat
      DisgruntledGoat about 14 years
      @Jared: You can go back to your old questions (click your username at the top) and accept answers on them if appropriate. More people will be likely to answer future questions.
  • Peter Bailey
    Peter Bailey about 14 years
    Updated your pattern to allow negatives.
  • swisstony
    swisstony about 14 years
    Daniel - what does this gobbledegook mean please? /[^0-9\.]+/g, ""
  • Alan
    Alan about 10 years
    Caveat Emptor: IF you can avoid fractional cents. In certain situations you cannot: ie aggregate tax calculation, non USD currency, etc.