numeral vs intl vs currency.js vs currency-formatter vs accounting-js
Currency Formatting and Manipulation Comparison
1 Year
numeralintlcurrency.jscurrency-formatteraccounting-jsSimilar Packages:
What's Currency Formatting and Manipulation?

Currency formatting and manipulation libraries in JavaScript provide tools for handling monetary values, including formatting numbers as currency, parsing currency strings, and performing arithmetic operations while considering currency-specific rules. These libraries help developers create applications that handle financial data accurately and display it in a user-friendly manner. They often include features like localization, support for multiple currencies, and functions for rounding, calculating taxes, and formatting values according to different cultural conventions. This is essential for e-commerce platforms, financial applications, and any software that deals with monetary transactions.

Package Weekly Downloads Trend
Github Stars Ranking
Stat Detail
Package
Downloads
Stars
Size
Issues
Publish
License
numeral1,322,3919,728-3498 years agoMIT
intl635,3971,699-799 years agoMIT
currency.js454,1813,307-584 years agoMIT
currency-formatter78,858213-154 years agoMIT
accounting-js36,07911546.9 kB82 months agoMIT
Feature Comparison: numeral vs intl vs currency.js vs currency-formatter vs accounting-js

Currency Formatting

  • numeral:

    numeral supports currency formatting as one of its features. It allows for customizable currency formats, including setting symbols, decimal places, and thousand separators, making it versatile for various formatting needs.

  • intl:

    The Intl API provides built-in support for currency formatting based on the user's locale. It is highly accurate and leverages the browser's native capabilities to format currency values according to international standards.

  • currency.js:

    currency.js focuses on precise currency representation and formatting. It allows for customizable formatting, including setting decimal places and currency symbols, while ensuring accuracy in calculations and display.

  • currency-formatter:

    currency-formatter specializes in formatting currency values according to locale and currency code, making it easy to display values accurately for different regions. It supports multiple currencies and allows for quick formatting with minimal configuration.

  • accounting-js:

    accounting-js provides simple currency formatting with customizable symbols, decimal places, and thousand separators. It is straightforward and effective for basic currency display needs.

Precision and Accuracy

  • numeral:

    numeral provides accurate formatting and manipulation of numbers, but it does not guarantee precision in calculations. It is important to manage precision manually, especially when dealing with large numbers or fractional values.

  • intl:

    The Intl API does not handle calculations; it focuses on accurate formatting of numbers, dates, and currencies based on locale. For precision in financial applications, additional handling is required during calculations.

  • currency.js:

    currency.js is designed for precision in currency calculations, addressing floating-point issues common in JavaScript. It provides accurate arithmetic operations, making it suitable for financial applications where precision is critical.

  • currency-formatter:

    currency-formatter is primarily focused on accurate formatting rather than calculations. It ensures that currency values are displayed correctly according to the specified locale and currency code, but it does not perform arithmetic operations.

  • accounting-js:

    accounting-js handles precision well for formatting and basic arithmetic operations. However, it is not specifically designed for high-precision calculations, so care should be taken with complex financial computations.

Arithmetic Operations

  • numeral:

    numeral provides basic arithmetic capabilities, but it is not its primary focus. The library allows for manipulation of numbers, including currency, but for complex calculations, additional handling may be required.

  • intl:

    The Intl API does not perform arithmetic operations. It is solely for formatting numbers, dates, and currencies according to locale. Arithmetic must be handled using standard JavaScript methods or other libraries.

  • currency.js:

    currency.js excels in arithmetic operations with currency values. It supports addition, subtraction, multiplication, and division while maintaining precision. The library is designed to handle calculations safely, making it ideal for financial applications.

  • currency-formatter:

    currency-formatter does not provide arithmetic operations. It is focused on formatting currency values rather than performing calculations. For arithmetic, you would need to handle it separately.

  • accounting-js:

    accounting-js supports basic arithmetic operations like addition, subtraction, multiplication, and division. It also provides functions for rounding and formatting numbers, making it useful for simple financial calculations.

Localization Support

  • numeral:

    numeral supports localization to some extent, allowing for custom number and currency formats. However, it does not provide automatic localization based on the user's settings, so developers need to implement it manually.

  • intl:

    The Intl API is built for localization and provides robust support for formatting numbers, dates, and currencies according to the user's locale. It is highly flexible and accurate, making it ideal for applications that require comprehensive localization features.

  • currency.js:

    currency.js has basic localization capabilities, allowing for customizable currency formatting. However, it does not provide extensive support for multiple locales or automatic localization based on user settings.

  • currency-formatter:

    currency-formatter provides excellent localization support, allowing currency formatting based on locale and currency code. It is designed to handle multiple currencies and regions, making it easy to display values accurately for different audiences.

  • accounting-js:

    accounting-js offers limited localization support, primarily for formatting numbers and currencies. It allows customization of symbols and separators, but it does not provide built-in support for multiple locales.

Ease of Use: Code Examples

  • numeral:

    Number Formatting with numeral

    // Import the library
    import numeral from 'numeral';
    
    // Format a number as currency
    const formattedCurrency = numeral(1234567.89).format('$0,0.00');
    console.log(formattedCurrency); // Output: $1,234,567.89
    
    // Perform basic arithmetic
    const sum = numeral(100).add(200);
    console.log(sum.value()); // Output: 300
    
  • intl:

    Currency Formatting with Intl API`

    // Format currency using the Intl API
    const amount = 1234567.89;
    const formatted = new Intl.NumberFormat('en-US', {
      style: 'currency',
      currency: 'USD',
    }).format(amount);
    console.log(formatted); // Output: $1,234,567.89
    
  • currency.js:

    Currency Operations with currency.js

    // Import the library
    import Currency from 'currency.js';
    
    // Create a currency instance
    const amount = Currency(1234.56);
    
    // Format the currency
    console.log(amount.format()); // Output: $1,234.56
    
    // Perform arithmetic operations
    const total = amount.add(100);
    console.log(total.format()); // Output: $1,334.56
    
  • currency-formatter:

    Currency Formatting with currency-formatter

    // Import the library
    import { format, parse } from 'currency-formatter';
    
    // Format a number as currency
    const formatted = format(1234567.89, { code: 'USD' });
    console.log(formatted); // Output: $1,234,567.89
    
    // Parse a currency string
    const parsed = parse('$1,234,567.89');
    console.log(parsed); // Output: 1234567.89
    
  • accounting-js:

    Simple Currency Formatting with accounting-js

    // Import the library
    import accounting from 'accounting-js';
    
    // Format a number as currency
    const formattedCurrency = accounting.formatMoney(1234567.89);
    console.log(formattedCurrency); // Output: $1,234,567.89
    
    // Perform basic arithmetic
    const sum = accounting.add(100, 200);
    console.log(sum); // Output: 300
    
How to Choose: numeral vs intl vs currency.js vs currency-formatter vs accounting-js
  • numeral:

    Choose numeral if you need a versatile library for formatting and manipulating numbers, including currency formatting. It offers a wide range of formatting options and is suitable for applications that require more than just currency handling, such as custom number formats and data visualization.

  • intl:

    Use the built-in Intl API if you want a native solution for internationalization, including currency formatting. It is part of the JavaScript standard and provides robust support for formatting numbers, dates, and currencies according to the user's locale, making it a good choice for applications that prioritize performance and reduce external dependencies.

  • currency.js:

    Opt for currency.js if you need a library that provides precise currency calculations, including addition, subtraction, multiplication, and division, while avoiding floating-point errors. It is suitable for applications that require accurate financial calculations and offers a clear API for working with monetary values.

  • currency-formatter:

    Select currency-formatter if you want a simple and efficient library for formatting currency values with support for multiple currencies and localization. It is easy to use and integrates well into projects that need quick currency formatting without extensive features.

  • accounting-js:

    Choose accounting-js if you need a lightweight library focused on simple currency formatting, number formatting, and basic arithmetic operations. It is ideal for projects that require minimal dependencies and straightforward functionality.

README for numeral

Numeral.js

A javascript library for formatting and manipulating numbers.

Website and documentation

Travis Build Status

Master Build Status

Develop Build Status

NPM

NPM

#CDNJS

CDNJS

Contributing

Important: Please create your branch from and submit pull requests to the develop branch. All pull requests must include the appropriate tests.

  1. Fork the library

  2. Install grunt

  3. Run npm install to install dependencies

  4. Create a new branch from develop

  5. Add your tests to the files in /tests

  6. To test your tests, run grunt

  7. When all your tests are passing, run grunt dist to compile and minify all files

  8. Submit a pull request to the develop branch.

Formats

Formats now exist in their own files and act more or less as plugins. Check out the bytes format for an example of how to create one.

Locales

When naming locale files use the ISO 639-1 language codes supplemented by ISO 3166-1 country codes when necessary.

Locale translations will not be merged without unit tests.

See the english unit tests for an example.

Changelog

2.0.6

Bug fix: Multi letter currency symbols and spacing

Added: Formatting of numbers with leading zeros

New format: Basic Point

Option: Added scalePercentBy100 (default: true) option to turn on/off scaling percentages

2.0.4

Bug fix: Incorrect abbreviations for values rounded up #187

Bug fix: Signed currency is inconsistent #89

2.0.2

Bug fix: Updated module definitions

2.0.1

Bug fix: Fixed regression for webpack/browserify/rollup

2.0.0

2.0.0 brings a lot of breaking changes and a reorganization of the repo, but also simplifies the api as well as the creating of custom formats.

Breaking change / Feature: All formats are now separate files. This makes it easy to create custom formats, and will also allow for custom builds with only certain formats. (Note: The built numeral.js still contains all formats in the repo).

Breaking change / Feature: All formats and locales are now loaded using numeral.register(type, name, {})

Breaking change: All language now renamed to locale and standardized to all lowercase filenames

Breaking change: The locale function no longer loads locales, it only sets the current locale

Breaking change: The unformat function has been removed numeral().unformat(string) and now happens on numeral init numeral(string)

Breaking change / Feature: Bytes are now formatted as: b (base 1000) and ib (base 1024)

Breaking change: numeral(NaN) is now treated the same as numeral(null) and no longer throws an error

Feature: Exponential format using e+ or e-

Bug fix: Update to floating point helpers (Note: Numeral does not fix JS floating point errors, but look to our tests to see that it covers quite a few cases.)

1.5.6

Bug fix: numeral converts strings to numbers

Bug fix: Null values return same as 0

1.5.5

Contained breaking changes, recommended to use 1.5.6

Bug fix: Switch bytes back to b and change iecBinary to ib, and calculate both using 1024 for backwards compatibility

1.5.4

Contained breaking changes, recommended to use 1.5.6

Tests: Changed all tests to use Mocha and Chai

Tests: Added browser tests for Chrome, Firefox, and IE using saucelabs

Added reset function to reset numeral to default options

Added nullFormat option

Update reduce polyfill

Added Binary bytes

Bug fix: Fixes problem with many optional decimals

1.5.3

Added currency symbol to optionally appear before negative sign / open paren

Added float precision math support

Added specification of abbreviation in thousands, millions, billions

1.5.2

Bug fix: Unformat should pass through if given a number

Added a mechanism to control rounding behaviour

Added languageData() for getting and setting language props at runtime

1.5.1

Bug fix: Make sure values aren't changed during formatting

1.5.0

Add defaultFormat(). numeral().format() uses the default to format if no string is provided

.unformat() returns 0 when passed no string

Added languages.js that contains all languages

Bug fix: Fix bug while unformatting ordinals

Add format option to always show signed value

Added ability to instantiate numeral with a string value of a number

1.4.9

Bug fix: Fix bug while unformatting ordinals

1.4.8

Bug fix: Throw error if language is not defined

1.4.7

Bug fix: Fix typo for trillion

1.4.6

Bug fix: remove ' from unformatting regex that was causing an error with fr-ch.js

1.4.5

Add zeroFormat() function that accepts a string for custom formating of zeros

Add valueOf() function

Chain functionality to language function

Make all minified files have the same .min.js filename ending

1.4.1

Bug fix: Bytes not formatting correctly

1.4.0

Add optional format for all decimals

1.3.4

Remove AMD module id. (This is encouraged by require.js to make the module more portable, and keep it from creating a global)

1.3.3

AMD define() compatibility.

1.3.2

Bug fix: Formatting some numbers results in the wrong value. Issue #21

1.3.1

Bug fix: Minor fix to unformatting parser

1.3.0

Add support for spaces before/after $, a, o, b in a format string

Bug fix: Fix unformat for languages that use '.' in ordinals

Bug fix: Fix round up floating numbers with no precision correctly.

Bug fix: Fix currency signs at the end in unformat

1.2.6

Add support for optional decimal places

1.2.5

Add support for appending currency symbol

1.2.4

Add support for humanized filesizes

1.2.3

Bug Fix: Fix unformatting for languages that use '.' as thousands delimiter

1.2.2

Changed language definition property 'money' to 'currency'

1.2.1

Bug fix: Fix unformatting non-negative abbreviations

1.2.0

Add language support

Update testing for to include languages

1.1.0

Add Tests

Bug fix: Fix difference returning negative values

1.0.4

Bug fix: Non negative numbers were displaying as negative when using parentheses

1.0.3

Add ordinal formatting using 'o' in the format

1.0.2

Add clone functionality

1.0.1

Added abbreviations for thousands and millions using 'a' in the format

1.0.0

Initial release

Acknowlegements

Numeral.js, while less complex, was inspired by and heavily borrowed from Moment.js

License

Numeral.js is freely distributable under the terms of the MIT license.

Copyright (c) 2012 Adam Draper

Permission is hereby granted, free of charge, to any person obtaining a copy of this software and associated documentation files (the "Software"), to deal in the Software without restriction, including without limitation the rights to use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of the Software, and to permit persons to whom the Software is furnished to do so, subject to the following conditions:

The above copyright notice and this permission notice shall be included in all copies or substantial portions of the Software.

THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.