1

I currently have some clean numbers like: 1, 10, 100, 1000, 10000 etc...

Im looking to format these numbers, so they appear as:

1,00
10,00
100,00
1.000,00
10.000,00

I played around with n.toFixed(2); but didn't seem to support the formatting im looking for.

Any ideas?

4

5 回答 5

4

Check out Intl.NumberFormat(), no fancy pants plugins needed. Cross-platform support.

var number = 3500;
alert(new Intl.NumberFormat().format(number));

Will pop up '3,500'

于 2013-10-10T23:01:55.430 回答
1

You can do it like this:

var nb='1000000000';
var result = nb.replace(/(?:(^\d{1,3})(?=(?:\d{3})*$)|(\d{3}))(?!$)/mg, '$1$2.')+',00';
于 2013-10-10T22:54:16.003 回答
1

If you want a simple function to do the job, the following may suit:

// Format a number n using: 
//   p decimal places (two by default)
//   ts as the thousands separator (comma by default) and
//   dp as the  decimal point (period by default).
//
//   If p < 0 or p > 20 results are implementation dependent.
function formatNumber(n, p, ts, dp) {
  var t = [];
  // Get arguments, set defaults
  if (typeof p  == 'undefined') p  = 2;
  if (typeof ts == 'undefined') ts = ',';
  if (typeof dp == 'undefined') dp = '.';

  // Get number and decimal part of n
  n = Number(n).toFixed(p).split('.');

  // Add thousands separator and decimal point (if requied):
  for (var iLen = n[0].length, i = iLen? iLen % 3 || 3 : 0, j = 0; i <= iLen; i+=3) {
    t.push(n[0].substring(j, i));
    j = i;
  }
  // Insert separators and return result
  return t.join(ts) + (n[1]? dp + n[1] : '');
}


//*
console.log(formatNumber(
    1234567890.567,  // value to format
                 4,  // number of decimal places
               '.',  // thousands separator
                ','  // decimal separator
 ));                 // result: 1.234.567.890,5670
//*/

console.log(formatNumber(
           123.567,  // value to format
                 1   // number of decimal places
 ));                 // result: 123.6

console.log(formatNumber(
         '123.567',  // value to format
                 0   // number of decimal places
 ));                 // result: 123.6

console.log(formatNumber(
               123,  // value to format
                 0   // number of decimal places
 ));                 // result: 123

console.log(formatNumber(
                13,  // value to format
                 2   // number of decimal places
 ));                 // result: 13.00

console.log(formatNumber(
                 0   // value to format
                     // number of decimal places
 ));                 // result: 0.00

console.log(formatNumber(
                     // value to format
                     // number of decimal places
 ));                 // result: NaN

Sorry, no fancy regular expressions or slice/splice array stuff, just POJS that works.

于 2013-10-11T00:40:58.103 回答
0

I don't know what your situation is, but i'd like to use angularJS.

It serves exactly what you are looking for and there are more extra dynamic formatting.

UPDATE: Specifically look into Localization functionality. It even serves pluralization if you need it.

于 2013-10-10T22:28:05.353 回答
0

There is no built-in methods for formatting numbers in JS. You can use autoNumeric for this. http://www.decorplanit.com/plugin/

于 2013-10-10T22:34:19.730 回答