Краткое и быстрое решение (работает везде!)
(12345.67).toFixed(2).replace(/\d(?=(\d{3})+\.)/g, '$&,'); // 12,345.67
Идея, лежащая в основе этого решения, заключается в замене соответствующих разделов первым соответствием и запятой, т.е. '$&,'
. Сопоставление выполняется с использованием подхода lookahead . Вы можете прочитать выражение как «соответствует номеру, если за ним следует последовательность из трех наборов чисел (один или несколько) и точка» .
ИСПЫТАНИЯ:
1 --> "1.00"
12 --> "12.00"
123 --> "123.00"
1234 --> "1,234.00"
12345 --> "12,345.00"
123456 --> "123,456.00"
1234567 --> "1,234,567.00"
12345.67 --> "12,345.67"
ДЕМО: http://jsfiddle.net/hAfMM/9571/
Расширенное короткое решение
Вы также можете расширить прототип объекта Number
, чтобы добавить дополнительную поддержку любого количества десятичных знаков [0 .. n]
и размера групп чисел [0 .. x]
:
/**
* Number.prototype.format(n, x)
*
* @param integer n: length of decimal
* @param integer x: length of sections
*/
Number.prototype.format = function(n, x) {
var re = '\\d(?=(\\d{' + (x || 3) + '})+' + (n > 0 ? '\\.' : '$') + ')';
return this.toFixed(Math.max(0, ~~n)).replace(new RegExp(re, 'g'), '$&,');
};
1234..format(); // "1,234"
12345..format(2); // "12,345.00"
123456.7.format(3, 2); // "12,34,56.700"
123456.789.format(2, 4); // "12,3456.79"
ДЕМО / ИСПЫТАНИЯ: http://jsfiddle.net/hAfMM/435/
Супер расширенное короткое решение
В этой супер расширенной версии вы можете установить различные типы разделителей:
/**
* Number.prototype.format(n, x, s, c)
*
* @param integer n: length of decimal
* @param integer x: length of whole part
* @param mixed s: sections delimiter
* @param mixed c: decimal delimiter
*/
Number.prototype.format = function(n, x, s, c) {
var re = '\\d(?=(\\d{' + (x || 3) + '})+' + (n > 0 ? '\\D' : '$') + ')',
num = this.toFixed(Math.max(0, ~~n));
return (c ? num.replace('.', c) : num).replace(new RegExp(re, 'g'), '$&' + (s || ','));
};
12345678.9.format(2, 3, '.', ','); // "12.345.678,90"
123456.789.format(4, 4, ' ', ':'); // "12 3456:7890"
12345678.9.format(0, 3, '-'); // "12-345-679"
ДЕМО / ИСПЫТАНИЯ: http://jsfiddle.net/hAfMM/612/