首页 > 解决方案 > 我的加千逗号功能不起作用

问题描述

我有一个函数可以将一个值转换为一个带有千位逗号的值,并且它适用于我的其他 html 表单之一,但不是这个。谁能看到我的代码有问题?

---javascript---

function numberWithCommas(x) {
      return x.toString().replace(/\B(?=(\d{3})+(?!\d))/g, ",");
  }
  function calcule2(){
  var i=0; for (i=0;i<= 29;i++) {calcule();}}
  function calcule(){

  var C20 = Excel2Html.C20.value=+parseFloat(Excel2Html.C19.value)*parseFloat(Excel2Html.E16.value)*4;
var C21 = Excel2Html.C21.value=+parseFloat(Excel2Html.C20.value)*0.22;

Excel2Html.C20.value=(numberWithCommas(C20));
Excel2Html.C21.value=(numberWithCommas(C21));

---html---

<input type="text" onchange="calcule2()" name="E16" value="100" size="5" style="background: #67823A; border: none; color: #ffffff;">
<input type="text" onchange="calcule2()" name="C20" value="196000" size="5" disabled="disabled">
<input type="text" onchange="calcule2()" name="C21" value="43120" size="5" disabled="disabled">

C20 返回 - 196000 C21 返回 - 43120

但是,它应该是:

C20 = 196,000 C21 = 43,120

标签: javascript

解决方案


已经有一些方法可以按照您正在寻找的方式格式化数字。

您可以使用toLocaleString()

function numberWithCommas(value) {
    return Number(value).toLocaleString("en");
}

document.querySelector("#number").addEventListener("input", function() {
  console.log(numberWithCommas(this.value));
});
<input type="number" id="number" />


推荐阅读