Javascript千位分隔符/字符串格式[重复]

Posted

技术标签:

【中文标题】Javascript千位分隔符/字符串格式[重复]【英文标题】:Javascript Thousand Separator / string format [duplicate] 【发布时间】:2011-04-14 18:52:51 【问题描述】:

javascript 中有没有用于格式化数字和字符串的函数?

我正在寻找一种用于字符串或数字的千位分隔符的方法... (类似于 c# 中的 String.Format)

【问题讨论】:

bytes.com/topic/c-sharp/answers/248039-formatcurrency-equiv 我想你会在那里找到你需要的东西:) ***.com/questions/610406/… How to print a number with commas as thousands separators in JavaScript: ***.com/questions/2901102/… 【参考方案1】:

更新(7 年后)

下面原始答案中引用的参考是错误的。 有一个内置函数,这正是kaiser 在下面建议的:toLocaleString

所以你可以这样做:

(1234567.89).toLocaleString('en')              // for numeric input
parseFloat("1234567.89").toLocaleString('en')  // for string input

下面实现的功能也可以,但根本不是必需的。

(我想也许我会很幸运,发现它在 2010 年 是必要的,但没有。根据more reliable reference,toLocaleString 自 ECMAScript 3rd 以来一直是标准的一部分版本 [1999],我相信这意味着它早在 IE 5.5 就已得到支持。)


原答案

根据this reference,没有用于将逗号添加到数字的内置函数。但是该页面包含一个如何自己编写代码的示例:

function addCommas(nStr) 
    nStr += '';
    var x = nStr.split('.');
    var x1 = x[0];
    var x2 = x.length > 1 ? '.' + x[1] : '';
    var rgx = /(\d+)(\d3)/;
    while (rgx.test(x1)) 
            x1 = x1.replace(rgx, '$1' + ',' + '$2');
    
    return x1 + x2;

编辑: 换一种方式(将带逗号的字符串转换为数字),您可以执行以下操作:

parseFloat("1,234,567.89".replace(/,/g,''))

【讨论】:

真的真的很欣赏它 // 但是我怎样才能将该字符串(带逗号)转换为数字? 这个函数对于大于 100,000 的数字会中断 @DevZer0 不,它没有 使用纯 javascript + 单个正则表达式替换 ***.com/a/44324879/681830 使用(1234567).toLocaleString().replace(/,/g," ",) 表示千位之间的空格【参考方案2】:

如果是关于本地化千位分隔符、定界符和小数分隔符,请使用以下内容:

// --> numObj.toLocaleString( [locales [, options] ] )
parseInt( number ).toLocaleString();

您可以使用多种选项(甚至可以使用具有后备功能的语言环境):

number = 123456.7089;

result  = parseInt( number ).toLocaleString() + "<br>";
result += number.toLocaleString( 'de-DE' ) + "<br>";
result += number.toLocaleString( 'ar-EG' ) + "<br>";
result += number.toLocaleString( 'ja-JP',  
  style           : 'currency',
  currency        : 'JPY',
  currencyDisplay : 'symbol',
  useGrouping     : true
 ) + "<br>";
result += number.toLocaleString( [ 'jav', 'en' ],  
  localeMatcher            : 'lookup',
  style                    : 'decimal',
  minimumIntegerDigits     : 2,
  minimumFractionDigits    : 2,
  maximumFractionDigits    : 3,
  minimumSignificantDigits : 2,
  maximumSignificantDigits : 3
 ) + "<br>";

var el = document.getElementById( 'result' );
el.innerhtml = result;
&lt;div id="result"&gt;&lt;/div&gt;

MDN info page 的详细信息。

编辑:评论者@I like Serena添加以下内容:

要支持具有非英语语言环境的浏览器,我们仍需要英文格式,请使用value.toLocaleString('en')。也适用于浮点数。

【讨论】:

这不包括浮点数。你可以将 parseInt 更改为 parseFloat,但如果 yourInt = "100,12"(逗号作为小数分隔符)这将失败。这可以用 replace(",",".").. 来修复,但会再次用 "1.000,12" 失败。所以...有时你必须重新发明***。 ***.com/a/2901298/1028304 这样更合适:Number(yourNumberOrString).toLocaleString() 要支持具有非英语语言环境的浏览器,我们仍然需要英文格式,请使用value.toLocaleString('en')。也适用于浮点数。 @Serhiog.Lazin 究竟是什么在 Safari 上不起作用(以及在哪个操作系统和哪个版本上)? 仅供参考,对于像 7,77,77,777 这样的印度数字格式,请使用 value.toLocaleString('en-IN')【参考方案3】:

根据 ECMAScript2018 更改使用后视支持进行了更新。 为了向后兼容,请进一步向下滚动以查看原始解决方案。

可以使用正则表达式——在处理存储为字符串的大数字时特别有用。

const format = num => 
    String(num).replace(/(?<!\..*)(\d)(?=(?:\d3)+(?:\.|$))/g, '$1,')

;[
    format(100),                           // "100"
    format(1000),                          // "1,000"
    format(1e10),                          // "10,000,000,000"  
    format(1000.001001),                   // "1,000.001001"
    format('100000000000000.001001001001') // "100,000,000,000,000.001001001001
]
    .forEach(n => console.log(n))

» Verbose regex explanation (regex101.com)


这个原始答案可能不是必需的,但可用于向后兼容。

尝试使用单个正则表达式处理此问题(无回调) 我目前的能力因 Javascript 中缺乏负面的后视而失败......不过,这里有另一个简洁的替代方案在大多数一般情况下 - 通过忽略匹配索引出现在句点索引之后的匹配来计算任何小数点。

const format = num => 
    const n = String(num),
          p = n.indexOf('.')
    return n.replace(
        /\d(?=(?:\d3)+(?:\.|$))/g,
        (m, i) => p < 0 || i < p ? `$m,` : m
    )


;[
    format(100),                           // "100"
    format(1000),                          // "1,000"
    format(1e10),                          // "10,000,000,000"  
    format(1000.001001),                   // "1,000.001001"
    format('100000000000000.001001001001') // "100,000,000,000,000.001001001001
]
    .forEach(n => console.log(n))

» Verbose regex explanation (regex101.com)

【讨论】:

这个语法图是在regex101.com上创建的吗? 带小数的数字会怎样? 我收到“无效的正则表达式:无效的组说明符名称”。在 React Native 0.59 上这样做,但这不应该影响 RegEx。 @JoshuaPinter 这将是使用look-behind,在撰写本文时,所有平台尚不支持。我猜你是专门指 ios - 因为 Safari 对我来说仍然失败。现在最好坚持使用向后兼容的版本。我只是想在未来证明我的答案。 caniuse.com/#search=lookbehind @Emissary 感谢您的提示。是的,它在 React Native 0.59 / android 上,它使用相对较旧版本的 JavaScriptCore (JSC)。我会在我们更新到 React Native 0.60+ 后重试,其中包括对 JSC 的更新。【参考方案4】:

有一个不错的 jQuery 数字插件:https://github.com/teamdf/jquery-number

它允许您以您喜欢的格式更改任何数字,带有十进制数字和十进制和千位分隔符的选项:

$.number(12345.4556, 2);          // -> 12,345.46
$.number(12345.4556, 3, ',', ' ') // -> 12 345,456

您可以直接在输入字段中使用它,这更好,使用与上面相同的选项:

$("input").number(true, 2);

或者您可以使用选择器应用于一整套 DOM 元素:

$('span.number').number(true, 2);

【讨论】:

最佳解决方案恕我直言 我不这么认为,添加一个将近800行的新文件要求,就像用手榴弹杀死一只蚂蚁【参考方案5】:

我用这个:

function numberWithCommas(number) 
    return number.toString().replace(/\B(?=(\d3)+(?!\d))/g, ",");

来源:link

【讨论】:

'123452343267.0505'.replace(/\B(?=(\d3)+(?!\d))/g, ","); "123,452,343,267.0,505" - 注意小数点后的最后一个逗号。【参考方案6】:
var number = 35002343;

console.log(number.toLocaleString());

您可以在这里查看参考 https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Number/toLocaleString

【讨论】:

哈哈哈试试这个 var n = 4720 console.log(n.toLocaleString()) 它不会工作【参考方案7】:
// thousand separates a digit-only string using commas
// by element:  onkeyup = "ThousandSeparate(this)"
// by ID:       onkeyup = "ThousandSeparate('txt1','lbl1')"
function ThousandSeparate()

    if (arguments.length == 1)
    
        var V = arguments[0].value;
        V = V.replace(/,/g,'');
        var R = new RegExp('(-?[0-9]+)([0-9]3)'); 
        while(R.test(V))
        
            V = V.replace(R, '$1,$2');
        
        arguments[0].value = V;
    
    else  if ( arguments.length == 2)
    
        var V = document.getElementById(arguments[0]).value;
        var R = new RegExp('(-?[0-9]+)([0-9]3)'); 
        while(R.test(V))
        
            V = V.replace(R, '$1,$2');
        
        document.getElementById(arguments[1]).innerHTML = V;
    
    else return false;
   

【讨论】:

【参考方案8】:

php.js 有一个名为number_format 的函数来执行此操作。如果您熟悉 PHP,则可以使用 exactly the same way。

【讨论】:

第一个链接是 PHP 版本的 JS 实现。很有用。【参考方案9】:

您可以使用 javascript。下面是代码,它只会accept 数字和一个dot

这里是javascript

<script >

            function FormatCurrency(ctrl) 
                //Check if arrow keys are pressed - we want to allow navigation around textbox using arrow keys
                if (event.keyCode == 37 || event.keyCode == 38 || event.keyCode == 39 || event.keyCode == 40) 
                    return;
                

                var val = ctrl.value;

                val = val.replace(/,/g, "")
                ctrl.value = "";
                val += '';
                x = val.split('.');
                x1 = x[0];
                x2 = x.length > 1 ? '.' + x[1] : '';

                var rgx = /(\d+)(\d3)/;

                while (rgx.test(x1)) 
                    x1 = x1.replace(rgx, '$1' + ',' + '$2');
                

                ctrl.value = x1 + x2;
            

            function CheckNumeric() 
                return event.keyCode >= 48 && event.keyCode <= 57 || event.keyCode == 46;
            

  </script>

HTML

<input type="text" onkeypress="return CheckNumeric()" onkeyup="FormatCurrency(this)" />

DEMO JSFIDDLE

【讨论】:

【参考方案10】:
number = 123456.7089;
result = parseInt( number ).toLocaleString() + "<br>";
result = number.toLocaleString( 'pt-BR' ) + "<br>";

var el = document.getElementById( 'result' );
el.innerHTML = result;
<div id="result"></div>

【讨论】:

能否请您也添加一些描述,以便 op 和其他人能够理解这段代码实际上是如何解决问题的。谢谢 尝试使用介于 1000 和 9999 之间的数字【参考方案11】:

你需要做的只是真的this:

123000.9123.toLocaleString()
//result will be "123,000.912"

【讨论】:

不幸的是,这取决于您的平台。有些有toLocaleString(),它不添加逗号,或者缺少标准中的其他功能。检查toLocaleString 的存在很容易,但检查其合规性并不容易。 尝试使用 1000 到 9999 之间的数字【参考方案12】:

react 解决方案的组合

  let converter = Intl.NumberFormat();
  let salary =  monthlySalary.replace(/,/g,'')
  console.log(converter.format(salary))

  this.setState(
    monthlySalary: converter.format(salary)
  )


handleOnChangeMonthlySalary(1000)```

【讨论】:

【参考方案13】:

您可以使用以下功能:

function format(number, decimals = 2, decimalSeparator = '.', thousandsSeparator = ',') 
  const roundedNumber = number.toFixed(decimals);
  let integerPart = '',
    fractionalPart = '';
  if (decimals == 0) 
    integerPart = roundedNumber;
    decimalSeparator = '';
   else 
    let numberParts = roundedNumber.split('.');
    integerPart = numberParts[0];
    fractionalPart = numberParts[1];
  
  integerPart = integerPart.replace(/(\d)(?=(\d3)+(?!\d))/g, `$1$thousandsSeparator`);
  return `$integerPart$decimalSeparator$fractionalPart`;


// Use Example

let min = 1556454.0001;
let max = 15556982.9999;

console.time('number format');
for (let i = 0; i < 15; i++) 
  let randomNumber = Math.random() * (max - min) + min;
  let formated = format(randomNumber, 4, ',', '.'); // formated number

  console.log('number: ', randomNumber, '; formated: ', formated);

console.timeEnd('number format');

【讨论】:

不要让它如此混乱。只需使用 toLocaleString()。更多信息developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/… @sajadsaderi 我也使用 toLocaleString() 朋友,但是这个函数并没有给我太大的灵活性,所以我不必处理区域缩写,其他人可以使用它,因为它的定义这个函数和php的number_format()函数是一样的。【参考方案14】:

我不喜欢这里的任何答案,所以我创建了一个对我有用的函数。只是想分享一下,以防其他人发现它有用。

function getFormattedCurrency(num) 
    num = num.toFixed(2)
    var cents = (num - Math.floor(num)).toFixed(2);
    return Math.floor(num).toLocaleString() + '.' + cents.split('.')[1];

【讨论】:

【参考方案15】:

您可以使用 ngx-format-field。这是一个用于格式化将出现在视图中的输入值的指令。它不会操纵将保存在后端的输入值。见链接here!

例子:

component.html:

<input type="text" formControlName="currency" [appFormatFields]="CURRENCY"
(change)="onChangeCurrency()">

component.ts

onChangeCurrency() 
this.currency.patchValue(this.currency.value);

观看演示:here!

【讨论】:

以上是关于Javascript千位分隔符/字符串格式[重复]的主要内容,如果未能解决你的问题,请参考以下文章

使用数字和千位分隔符修复格式错误的字符串

数字格式,去掉千位分隔符

ActionScript 3 将数字格式化为字符串 - 使用小数和千位分隔符

如何将双精度值格式化为点后两位小数且分隔符为千位的字符串?

将数字格式化为字符串-带小数和千位分隔符

使用美元符号和千位分隔符格式化引导表 [关闭]