У меня есть следующий код для отображения в индийской системе нумерации.
var x=125465778;
var res= x.toString().replace(/\B(?=(\d{3})+(?!\d))/g, ",");
Я получаю этот вывод: 125,465,778.
Мне нужен вывод следующим образом: 12,54,65,778.
Пожалуйста, помогите мне разобраться в этом проблема.
number.toLocaleString('en-IN');
Это поможет вам отобразить в индийской системе нумерации. Посмотрите документацию
С учетом функции числа ниже, она возвращает форматированный номер в индийском формате группировки цифр.
ex: input: 12345678567545.122343 output: 1,23,45,67,85,67,545.122343function formatNumber(num) {
var n1, n2;
num = num + '' || '';
// works for integer and floating as well
n1 = num.split('.');
n2 = n1[1] || null;
n1 = n1[0].replace(/(\d)(?=(\d\d)+\d$)/g, "$1,");
num = n2 ? n1 + '.' + n2 : n1;
return num;
}
https://jsfiddle.net/scLtnug8/1/
Вот функция
function numberWithCommas(x) {
return x.toString().substring(0,x.toString().split('.')[0].length-3).replace(/\B(?=(\d{2})+(?!\d))/g, ",") + "," + x.toString().substring(x.toString().split('.')[0].length-3);
}
, если ваш вход 10000.5,
numberWithCommas(10000.5)
Вы получите такой вывод, 10,000.5
На основании вопроса Нидхинкумара я проверил приведенные выше ответы и при обработке отрицательных чисел выход будет неправильным, например: -300, он должен отображаться как -300, но вышеприведенные ответы будут отображать его как -, 300, который не является хорошо, поэтому я попытался использовать код ниже, который работает даже во время отрицательных случаев.
var negative = input < 0;
var str = negative ? String(-input) : String(input);
var arr = [];
var i = str.indexOf('.');
if (i === -1) {
i = str.length;
} else {
for (var j = str.length - 1; j > i; j--) {
arr.push(str[j]);
}
arr.push('.');
}
i--;
for (var n = 0; i >= 0; i--, n++) {
if (n > 2 && (n % 2 === 1)) {
arr.push(',');
}
arr.push(str[i]);
}
if (negative) {
arr.push('-');
}
return arr.reverse().join('');
Это должно работать.
var number=12345678;
alert(number.toLocaleString());
вы также можете передать аргументы внутри функции здесь, если defualt примет международную конвенцию. Если вы хотите использовать индийское соглашение, то u должен написать его так:
alert(number.toLocaleString("hi-IN"));
Но этот код будет работать только на Chrome, Mozzilla и IE. Это не будет работать в Safari.
Попробуйте, как показано ниже, я нашел плагин формата formatter здесь: номер скрипта Java Formatter
Используя это, я сделал код ниже, он отлично работает, попробуйте, это поможет вам ..
SCRIPT:
<script src="format.20110630-1100.min.js" type="text/javascript"></script>
<script>
var FullData = format( "#,##0.####", 125465778)
var n=FullData.split(",");
var part1 ="";
for(i=0;i<n.length-1;i++)
part1 +=n[i];
var part2 = n[n.length-1]
alert(format( "#0,#0.####", part1) + "," + part2);
</script>
SCRIPT:
1) 125465778
2) 1234567.89
Выходы:
1) 12,54,65,778
2) 12,34,567.89
Для целых чисел не требуется никаких дополнительных манипуляций.
Это будет соответствовать каждой цифре с конца, с последующим 1 или более двухзначным рисунком, и заменить ее на себя + ",":
"125465778".replace(/(\d)(?=(\d\d)+$)/g, "$1,");
-> "1,25,46,57,78"
Но так как мы хотим иметь 3 в конце, давайте укажем это явно, добавив дополнительные «\ d» до окончания конца ввода:
"125465778".replace(/(\d)(?=(\d\d)+\d$)/g, "$1,");
-> "12,54,65,778"
Самый простой способ - просто использовать плагин глобализации (подробнее об этом здесь и здесь):
var value = 125465778;
var formattedValue = Globalize.format(value, 'n');
Я опаздываю, но думаю, это поможет:)
вы можете использовать Number.prototype.toLocaleString ()
Синтаксис
numObj.toLocaleString([locales [, options]])
var number = 123456.789;
// India uses thousands/lakh/crore separators
document.getElementById('result').innerHTML = number.toLocaleString('en-IN');
// → 1,23,456.789
document.getElementById('result1').innerHTML = number.toLocaleString('en-IN', {
maximumFractionDigits: 2,
style: 'currency',
currency: 'INR'
});
// → Rs.123,456.79
<div id="result"></div>
<div id="result1"></div>
Просто используйте https://osrec.github.io/currencyFormatter.js/
Тогда вам понадобится следующее:
OSREC.CurrencyFormatter.format(2534234, { currency: 'INR' });
// Returns ₹ 25,34,234.00
Эта функция может корректно обрабатывать значение float, просто добавляя к другому ответу
function convertNumber(num) {
var n1, n2;
num = num + '' || '';
n1 = num.split('.');
n2 = n1[1] || null;
n1 = n1[0].replace(/(\d)(?=(\d\d)+\d$)/g, "$1,");
num = n2 ? n1 + '.' + n2 : n1;
n1 = num.split('.');
n2 = (n1[1]) || null;
if (n2 !== null) {
if (n2.length <= 1) {
n2 = n2 + '0';
} else {
n2 = n2.substring(0, 2);
}
}
num = n2 ? n1[0] + '.' + n2 : n1[0];
return num;
}
эта функция преобразует всю функцию в float, как это
function formatAndConvertToFloatFormat(num) {
var n1, n2;
num = num + '' || '';
n1 = num.split('.');
if (n1[1] != null){
if (n1[1] <= 9) {
n2 = n1[1]+'0';
} else {
n2 = n1[1]
}
} else {
n2 = '00';
}
n1 = n1[0].replace(/(\d)(?=(\d\d)+\d$)/g, "$1,");
return n1 + '.' + n2;
}