亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 語言 > JavaScript > 正文

JS實現的4種數字千位符格式化方法分享

2024-05-06 16:15:40
字體:
來源:轉載
供稿:網友
這篇文章主要介紹了JS實現的4種數字千位符格式化方法分享,本文給出了4種千分位格式化方法并對它們的性能做了比較,需要的朋友可以參考下
 

所謂的數字千分位形式,即從個位數起,每三位之間加一個逗號。例如“10,000”。針對這個需求,我起初寫了這樣一個函數:

復制代碼代碼如下:

// 方法一
function toThousands(num) {
    var result = [ ], counter = 0;
    num = (num || 0).toString().split('');
    for (var i = num.length - 1; i >= 0; i--) {
        counter++;
        result.unshift(num[i]);
        if (!(counter % 3) && i != 0) { result.unshift(','); }
    }
    return result.join('');
}

方法一的執行過程就是把數字轉換成字符串后,打散為數組,再從末尾開始,逐個把數組中的元素插入到新數組(result)的開頭。每插入一個元素,counter就計一次數(加1),當counter為3的倍數時,就插入一個逗號,但是要注意開頭(i為0時)不需要逗號。最后通過調用新數組的join方法得出結果。

 

方法一比較清晰易懂,也在項目中用了一段時間。但是直覺告訴我,它的性能并不好。

方法二——方法一的字符串版

復制代碼代碼如下:

// 方法二
function toThousands(num) {
    var result = '', counter = 0;
    num = (num || 0).toString();
    for (var i = num.length - 1; i >= 0; i--) {
        counter++;
        result = num.charAt(i) + result;
        if (!(counter % 3) && i != 0) { result = ',' + result; }
    }
    return result;
}

方法二是方法一的改良版,不把字符串打散為數組,始終對字符串操作。

 

方法三——循環匹配末尾的三個數字

復制代碼代碼如下:

// 方法三
function toThousands(num) {
    var num = (num || 0).toString(), re = //d{3}$/, result = '';
    while ( re.test(num) ) {
        result = RegExp.lastMatch + result;
        if (num !== RegExp.lastMatch) {
            result = ',' + result;
            num = RegExp.leftContext;
        } else {
            num = '';
            break;
        }
    }
    if (num) { result = num + result; }
    return result;
}

 

方法三是完全不同的算法,通過正則表達式循環匹配末尾的三個數字,每匹配一次,就把逗號和匹配到的內容插入到結果字符串的開頭,然后把匹配目標(num)賦值為還沒匹配的內容(RegExp.leftContext)。此外,還要注意:

1.如果數字的位數是3的倍數時,最后一次匹配到的內容肯定是三個數字,但是最前面的三個數字前不需要加逗號;
2.如果數字的位數不是3的倍數,那num變量最后肯定會剩下1到2個數字,循環過后,要把剩余的數字插入到結果字符串的開頭。

雖然方法三減少了循環次數(一次循環處理三個字符),但由于用到了正則表達式,一定程度上增加了消耗。

方法四——方法三的字符串版

復制代碼代碼如下:

// 方法四
function toThousands(num) {
    var num = (num || 0).toString(), result = '';
    while (num.length > 3) {
        result = ',' + num.slice(-3) + result;
        num = num.slice(0, num.length - 3);
    }
    if (num) { result = num + result; }
    return result;
}

 

事實上,截取末尾三個字符的功能可以通過字符串類型的slice、substr或substring方法做到。這樣就可以避免使用正則表達式。

方法五——分組合并法

復制代碼代碼如下:

// 方法五
function toThousands(num) {
    var num = (num || 0).toString(), temp = num.length % 3;
    switch (temp) {
        case 1:
            num = '00' + num;
            break;
        case 2:
            num = '0' + num;
            break;
    }
    return num.match(//d{3}/g).join(',').replace(/^0+/, '');
}

 

先把數字的位數補足為3的倍數,通過正則表達式,將其切割成每三個數字一個分組,再通過join方法添加逗號,最后還要把補的0移除。

方法六——懶人法

復制代碼代碼如下:

// 方法六
function toThousands(num) {
    return (num || 0).toString().replace(/(/d)(?=(?:/d{3})+$)/g, '$1,');
}

?一直覺得這個格式化是可以通過一條正則表達式替換做出來的,但是需要用到斷言等寫法,無奈自己對這部分不太熟。Google了一下,還真找到了這么一條正則表達式,這估計是代碼最短的實現。

 

測試結果

 

數字 執行5000次消耗的時間(ms)
方法一 方法二 方法三 方法四 方法五 方法六
1 4 1 3 1 14 2
10 14 1 3 0 7 2
100 12 1 2 4 5 3
1000 13 2 3 2 9 5
10000 21 4 3 1 6 3
100000 21 3 2 1 5 6

 

方法一和方法二的強烈對比表明,字符串操作的效率比數組操作的效率要高得多;方法六的測試結果告訴我們,代碼長短跟性能高低沒有關系。方法四的綜合性能是最好的(但為何num為100的時候,性能有所降低呢,這個實在不解),主要原因是:

1.對比方法一、二,每次操作3個字符而不是1個字符,減少循環次數;
2.對比方法三、五、六,沒有使用正則表達式,減少了消耗。

最后,我選擇了方法四作為最終的優化方案。各位讀者如有更好的實現方法或改良意見,可以發表評論。


發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表

圖片精選

亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
久久久99免费视频| 欧美在线视频网站| 热久久视久久精品18亚洲精品| 久久免费国产视频| 日韩电影中文字幕| 亚洲色图国产精品| 2018中文字幕一区二区三区| 国产精品欧美日韩久久| 国产精品久久久久久久久久久不卡| 欧美激情一区二区三区久久久| 日韩精品视频在线免费观看| 91成人在线播放| 国产精品久久久久av| 欧美性在线视频| 国产精品美女主播在线观看纯欲| 69av视频在线播放| 欧美高清在线视频观看不卡| 国产精品白嫩初高中害羞小美女| 日韩在线观看免费全| 亚洲国产97在线精品一区| 亚洲bt欧美bt日本bt| 91精品国产91久久久久久不卡| 国外日韩电影在线观看| 欧美激情精品久久久久久免费印度| 亚洲综合最新在线| 亚洲网站在线看| 日韩最新在线视频| 91九色国产社区在线观看| 欧美在线观看www| 亚洲男人天堂久| 日韩免费看的电影电视剧大全| 成人动漫网站在线观看| 国产日韩在线精品av| 国产成人jvid在线播放| 国产91成人video| 欧洲成人性视频| 精品女厕一区二区三区| 亚洲自拍偷拍色图| 欧美成人免费网| 亚洲小视频在线观看| 97精品一区二区三区| 精品久久国产精品| 在线日韩中文字幕| 激情亚洲一区二区三区四区| 色香阁99久久精品久久久| 国产综合在线看| 一区二区三区 在线观看视| 亚洲色图激情小说| 精品国产欧美一区二区五十路| 在线中文字幕日韩| 亚洲成人久久一区| 在线中文字幕日韩| 91久热免费在线视频| 国产日韩在线一区| 91久久中文字幕| 国产91色在线免费| 97国产精品人人爽人人做| 国产精品视频久久久| 中文字幕久久亚洲| 91在线免费观看网站| 久久99热这里只有精品国产| 亚洲性生活视频在线观看| 中文字幕亚洲国产| 亚洲欧美日韩精品| 国产成人一区二区三区| 久久躁日日躁aaaaxxxx| 国产精品第100页| 国产99久久精品一区二区| 亚洲欧美精品中文字幕在线| 国产精品第三页| 国产精品中文字幕在线观看| 国产99久久久欧美黑人| 欧美视频在线免费看| 欧美亚洲日本网站| 国产亚洲精品久久久久动| 国产精品久久网| 亚洲亚裔videos黑人hd| 亚洲成人性视频| 亚洲国产精品视频在线观看| 日韩高清电影免费观看完整| 狠狠色狠狠色综合日日五| 成人精品视频久久久久| 久久噜噜噜精品国产亚洲综合| 国产亚洲精品一区二555| 亚洲国产私拍精品国模在线观看| 成人黄色在线观看| 日韩在线观看成人| 成人xvideos免费视频| 国产人妖伪娘一区91| 国产精品美女久久久久av超清| 国产日韩欧美视频在线| 日韩在线不卡视频| 日韩视频免费观看| 精品国产91久久久| 亚洲影院色无极综合| 久久亚洲精品网站| 欧美超级免费视 在线| 国产成人精品日本亚洲专区61| 欧美日韩中文字幕综合视频| 国产精品∨欧美精品v日韩精品| 欧美日韩成人网| 亚洲人成在线一二| 亚洲精品白浆高清久久久久久| 欧美激情精品久久久久久| 亚洲理论电影网| 欧美日韩国产在线播放| 国产精品久久久久久久久借妻| 欧美日产国产成人免费图片| 久久av.com| 亚洲午夜久久久影院| 91精品久久久久| 国内精品久久久久影院 日本资源| 激情av一区二区| 亚洲天堂视频在线观看| 视频在线观看99| 7m精品福利视频导航| 亚洲国产精品va在线观看黑人| 国产日韩中文字幕在线| 97视频免费在线看| 亚洲精品久久久久久久久久久久久| 欧美性xxxx极品高清hd直播| 亚洲香蕉成视频在线观看| 久热精品视频在线| 久久久国产视频91| 欧美另类老肥妇| 久久精品国产一区二区电影| 欧美精品videosex牲欧美| www日韩中文字幕在线看| 亚洲自拍小视频| 激情成人中文字幕| 久久成人精品视频| 亚洲aⅴ男人的天堂在线观看| 欧美一区二区三区精品电影| 亚洲福利视频在线| 97在线观看视频国产| 国产视频亚洲视频| 精品久久香蕉国产线看观看gif| 亚洲精品综合久久中文字幕| 国产脚交av在线一区二区| 亚洲国产成人爱av在线播放| 欧美性xxxx极品高清hd直播| 亚洲视频在线免费看| 午夜精品一区二区三区在线视频| 91九色精品视频| 97香蕉超级碰碰久久免费的优势| 亚洲精品大尺度| 国产一区二区在线播放| 精品亚洲精品福利线在观看| 清纯唯美日韩制服另类| 国产亚洲aⅴaaaaaa毛片| 中文字幕亚洲情99在线| 久久在线免费观看视频| 日韩高清有码在线| 2018中文字幕一区二区三区| 久久97久久97精品免视看| 亚洲自拍高清视频网站| 久久久免费观看视频| 午夜精品久久久久久久99热| 日本精品va在线观看| 久久韩剧网电视剧| 欧美性高潮在线| 久久久久久久国产精品视频| 成人淫片在线看| 欧美电影免费观看电视剧大全|