久久久久久久av_日韩在线中文_看一级毛片视频_日本精品二区_成人深夜福利视频_武道仙尊动漫在线观看

  • <small id='gDc0k'></small><noframes id='gDc0k'>

      <legend id='gDc0k'><style id='gDc0k'><dir id='gDc0k'><q id='gDc0k'></q></dir></style></legend>

        <bdo id='gDc0k'></bdo><ul id='gDc0k'></ul>

    1. <i id='gDc0k'><tr id='gDc0k'><dt id='gDc0k'><q id='gDc0k'><span id='gDc0k'><b id='gDc0k'><form id='gDc0k'><ins id='gDc0k'></ins><ul id='gDc0k'></ul><sub id='gDc0k'></sub></form><legend id='gDc0k'></legend><bdo id='gDc0k'><pre id='gDc0k'><center id='gDc0k'></center></pre></bdo></b><th id='gDc0k'></th></span></q></dt></tr></i><div class="qwawimqqmiuu" id='gDc0k'><tfoot id='gDc0k'></tfoot><dl id='gDc0k'><fieldset id='gDc0k'></fieldset></dl></div>
      1. <tfoot id='gDc0k'></tfoot>

      2. 如何在 JavaScript 中用逗號打印一個數字作為千位

        How to print a number with commas as thousands separators in JavaScript(如何在 JavaScript 中用逗號打印一個數字作為千位分隔符)

        1. <i id='8JpAG'><tr id='8JpAG'><dt id='8JpAG'><q id='8JpAG'><span id='8JpAG'><b id='8JpAG'><form id='8JpAG'><ins id='8JpAG'></ins><ul id='8JpAG'></ul><sub id='8JpAG'></sub></form><legend id='8JpAG'></legend><bdo id='8JpAG'><pre id='8JpAG'><center id='8JpAG'></center></pre></bdo></b><th id='8JpAG'></th></span></q></dt></tr></i><div class="qwawimqqmiuu" id='8JpAG'><tfoot id='8JpAG'></tfoot><dl id='8JpAG'><fieldset id='8JpAG'></fieldset></dl></div>
          <tfoot id='8JpAG'></tfoot>
              <tbody id='8JpAG'></tbody>
            1. <small id='8JpAG'></small><noframes id='8JpAG'>

                  <bdo id='8JpAG'></bdo><ul id='8JpAG'></ul>

                  <legend id='8JpAG'><style id='8JpAG'><dir id='8JpAG'><q id='8JpAG'></q></dir></style></legend>
                  本文介紹了如何在 JavaScript 中用逗號打印一個數字作為千位分隔符的處理方法,對大家解決問題具有一定的參考價值,需要的朋友們下面隨著小編來一起學習吧!

                  問題描述

                  限時送ChatGPT賬號..

                  我正在嘗試在 JavaScript 中打印一個整數,并用逗號作為千位分隔符.例如,我想將數字 1234567 顯示為1,234,567".我該怎么做呢?

                  I am trying to print an integer in JavaScript with commas as thousands separators. For example, I want to show the number 1234567 as "1,234,567". How would I go about doing this?

                  這是我的做法:

                  function numberWithCommas(x) {
                      x = x.toString();
                      var pattern = /(-?d+)(d{3})/;
                      while (pattern.test(x))
                          x = x.replace(pattern, "$1,$2");
                      return x;
                  }
                  

                  有沒有更簡單或更優雅的方法來做到這一點?如果它也適用于浮點數會很好,但這不是必需的.在句點和逗號之間決定不需要特定于語言環境.

                  Is there a simpler or more elegant way to do it? It would be nice if it works with floats also, but that is not necessary. It does not need to be locale-specific to decide between periods and commas.

                  推薦答案

                  我使用了 Kerry 的回答中的想法,但簡化了它,因為我只是為我的特定目的尋找簡單的東西.這是我所擁有的:

                  I used the idea from Kerry's answer, but simplified it since I was just looking for something simple for my specific purpose. Here is what I have:

                  function numberWithCommas(x) {
                      return x.toString().replace(/B(?=(d{3})+(?!d))/g, ",");
                  }
                  

                  function numberWithCommas(x) {
                      return x.toString().replace(/B(?<!.d*)(?=(d{3})+(?!d))/g, ",");
                  }
                  
                  function test(x, expect) {
                      const result = numberWithCommas(x);
                      const pass = result === expect;
                      console.log(`${pass ? "?" : "ERROR ====>"} ${x} => ${result}`);
                      return pass;
                  }
                  
                  let failures = 0;
                  failures += !test(0,        "0");
                  failures += !test(100,      "100");
                  failures += !test(1000,     "1,000");
                  failures += !test(10000,    "10,000");
                  failures += !test(100000,   "100,000");
                  failures += !test(1000000,  "1,000,000");
                  failures += !test(10000000, "10,000,000");
                  if (failures) {
                      console.log(`${failures} test(s) failed`);
                  } else {
                      console.log("All tests passed");
                  }

                  .as-console-wrapper {
                      max-height: 100% !important;
                  }

                  正則表達式使用 2 個前瞻斷言:

                  The regex uses 2 lookahead assertions:

                  • 一個正數,用于查找字符串中后面連續有 3 個數字的倍數的任何點,
                  • 一個否定斷言,以確保該點僅具有 3 位數字的倍數.替換表達式在此處放置一個逗號.

                  例如,如果你傳遞它 123456789.01,肯定斷言將匹配 7 左邊的每個點(因為 789 是 3 位的倍數,678 是 3 位的倍數,567 等).否定斷言檢查 3 位的倍數后面沒有任何數字.789 后面有一個句點,所以它正好是 3 位數字的倍數,所以用逗號.678 是 3 位數字的倍數,但它后面有一個 9,所以這 3 位數字是一組 4 的一部分,逗號不會去那里.567 也是如此.456789 是 6 位數字,是 3 的倍數,所以前面要加逗號.345678 是 3 的倍數,但它后面有一個 9,所以那里沒有逗號.等等.B 防止正則表達式在字符串開頭放置逗號.

                  For example, if you pass it 123456789.01, the positive assertion will match every spot to the left of the 7 (since 789 is a multiple of 3 digits, 678 is a multiple of 3 digits, 567, etc.). The negative assertion checks that the multiple of 3 digits does not have any digits after it. 789 has a period after it so it is exactly a multiple of 3 digits, so a comma goes there. 678 is a multiple of 3 digits but it has a 9 after it, so those 3 digits are part of a group of 4, and a comma does not go there. Similarly for 567. 456789 is 6 digits, which is a multiple of 3, so a comma goes before that. 345678 is a multiple of 3, but it has a 9 after it, so no comma goes there. And so on. The B keeps the regex from putting a comma at the beginning of the string.

                  @neu-rah 提到如果后面有超過 3 個數字,這個函數會在不需要的地方添加逗號小數點.如果這是一個問題,你可以使用這個功能:

                  @neu-rah mentioned that this function adds commas in undesirable places if there are more than 3 digits after the decimal point. If this is a problem, you can use this function:

                  function numberWithCommas(x) {
                      var parts = x.toString().split(".");
                      parts[0] = parts[0].replace(/B(?=(d{3})+(?!d))/g, ",");
                      return parts.join(".");
                  }
                  

                  function numberWithCommas(x) {
                      var parts = x.toString().split(".");
                      parts[0] = parts[0].replace(/B(?=(d{3})+(?!d))/g, ",");
                      return parts.join(".");
                  }
                  
                  function test(x, expect) {
                      const result = numberWithCommas(x);
                      const pass = result === expect;
                      console.log(`${pass ? "?" : "ERROR ====>"} ${x} => ${result}`);
                      return pass;
                  }
                  
                  let failures = 0;
                  failures += !test(0              , "0");
                  failures += !test(0.123456       , "0.123456");
                  failures += !test(100            , "100");
                  failures += !test(100.123456     , "100.123456");
                  failures += !test(1000           , "1,000");
                  failures += !test(1000.123456    , "1,000.123456");
                  failures += !test(10000          , "10,000");
                  failures += !test(10000.123456   , "10,000.123456");
                  failures += !test(100000         , "100,000");
                  failures += !test(100000.123456  , "100,000.123456");
                  failures += !test(1000000        , "1,000,000");
                  failures += !test(1000000.123456 , "1,000,000.123456");
                  failures += !test(10000000       , "10,000,000");
                  failures += !test(10000000.123456, "10,000,000.123456");
                  if (failures) {
                      console.log(`${failures} test(s) failed`);
                  } else {
                      console.log("All tests passed");
                  }

                  .as-console-wrapper {
                      max-height: 100% !important;
                  }

                  @tjcrowder 指出,現在 JavaScript 有lookbehind (支持信息),可以在正則表達式本身解決:

                  @t.j.crowder pointed out that now that JavaScript has lookbehind (support info), it can be solved in the regular expression itself:

                  function numberWithCommas(x) {
                      return x.toString().replace(/B(?<!.d*)(?=(d{3})+(?!d))/g, ",");
                  }
                  

                  function numberWithCommas(x) {
                      return x.toString().replace(/B(?<!.d*)(?=(d{3})+(?!d))/g, ",");
                  }
                  
                  function test(x, expect) {
                      const result = numberWithCommas(x);
                      const pass = result === expect;
                      console.log(`${pass ? "?" : "ERROR ====>"} ${x} => ${result}`);
                      return pass;
                  }
                  
                  let failures = 0;
                  failures += !test(0,               "0");
                  failures += !test(0.123456,        "0.123456");
                  failures += !test(100,             "100");
                  failures += !test(100.123456,      "100.123456");
                  failures += !test(1000,            "1,000");
                  failures += !test(1000.123456,     "1,000.123456");
                  failures += !test(10000,           "10,000");
                  failures += !test(10000.123456,    "10,000.123456");
                  failures += !test(100000,          "100,000");
                  failures += !test(100000.123456,   "100,000.123456");
                  failures += !test(1000000,         "1,000,000");
                  failures += !test(1000000.123456,  "1,000,000.123456");
                  failures += !test(10000000,        "10,000,000");
                  failures += !test(10000000.123456, "10,000,000.123456");
                  if (failures) {
                      console.log(`${failures} test(s) failed`);
                  } else {
                      console.log("All tests passed");
                  }

                  .as-console-wrapper {
                      max-height: 100% !important;
                  }

                  (?<!.d*) 是一個否定的lookbehind,表示匹配項前面不能有 . 后跟零個或多個數字.負面的lookbehind比splitjoin解決方案更快(比較),至少在 V8 中.

                  (?<!.d*) is a negative lookbehind that says the match can't be preceded by a . followed by zero or more digits. The negative lookbehind is faster than the split and join solution (comparison), at least in V8.

                  這篇關于如何在 JavaScript 中用逗號打印一個數字作為千位分隔符的文章就介紹到這了,希望我們推薦的答案對大家有所幫助,也希望大家多多支持html5模板網!

                  【網站聲明】本站部分內容來源于互聯網,旨在幫助大家更快的解決問題,如果有圖片或者內容侵犯了您的權益,請聯系我們刪除處理,感謝您的支持!

                  相關文檔推薦

                  Browserify, Babel 6, Gulp - Unexpected token on spread operator(Browserify,Babel 6,Gulp - 傳播運算符上的意外令牌)
                  Is it possible to pass a flag to Gulp to have it run tasks in different ways?(是否可以將標志傳遞給 Gulp 以使其以不同的方式運行任務?)
                  Why do we need to install gulp globally and locally?(為什么我們需要在全局和本地安裝 gulp?)
                  How to run Gulp tasks sequentially one after the other(如何一個接一個地依次運行 Gulp 任務)
                  Visual Studio 2015 crashes when opening Javascript files(打開 Javascript 文件時 Visual Studio 2015 崩潰)
                  Detect FLASH plugin crashes(檢測 FLASH 插件崩潰)
                  • <small id='M654J'></small><noframes id='M654J'>

                      <bdo id='M654J'></bdo><ul id='M654J'></ul>
                      1. <i id='M654J'><tr id='M654J'><dt id='M654J'><q id='M654J'><span id='M654J'><b id='M654J'><form id='M654J'><ins id='M654J'></ins><ul id='M654J'></ul><sub id='M654J'></sub></form><legend id='M654J'></legend><bdo id='M654J'><pre id='M654J'><center id='M654J'></center></pre></bdo></b><th id='M654J'></th></span></q></dt></tr></i><div class="qwawimqqmiuu" id='M654J'><tfoot id='M654J'></tfoot><dl id='M654J'><fieldset id='M654J'></fieldset></dl></div>
                        <legend id='M654J'><style id='M654J'><dir id='M654J'><q id='M654J'></q></dir></style></legend>

                            <tfoot id='M654J'></tfoot>

                              <tbody id='M654J'></tbody>
                            主站蜘蛛池模板: 免费成年网站 | 99国内精品久久久久久久 | 色综合国产 | 国产高清免费 | 久久伊人精品 | 欧美日韩一本 | 国产高清视频 | 国产精品成人av | 少妇av片| 婷婷毛片 | 黄色91在线| 久久久久国产精品一区二区 | 欧美综合色 | 国产乱码高清区二区三区在线 | 亚洲欧美在线一区 | 国产伦一区二区三区视频 | 色婷婷亚洲国产女人的天堂 | 午夜精品久久久久久久久久久久久 | 亚洲欧美一区二区三区国产精品 | 日本一区二区高清视频 | 日韩一区不卡 | av激情在线 | 亚洲综合在线网 | 亚洲一区在线日韩在线深爱 | 九九热在线免费观看 | www久久| 久久草在线视频 | 亚洲网址在线观看 | 欧产日产国产精品视频 | 久久成人免费视频 | 一区天堂| 中文字幕一区二区三区精彩视频 | 四虎影院一区二区 | www.97zyz.com| 综合国产| 日本成人一区二区 | 成人h视频在线 | 91资源在线 | 在线欧美日韩 | 欧美成人免费在线 | 国产成人高清 |