文章出處

在項目里碰到需要把類似'450000'的數字轉換為會計記賬所用的格式,'450,000.00',分隔千分位和小數點后不夠兩位數時自動補齊,已下記錄幾種實現的方式

ps:如果不考慮后面的小數點,最快捷的方法(by:javascript后花園(原羅浮宮3群)):

"12345678".replace(/[0-9]+?(?=(?:([0-9]{3}))+$)/g,function(a){return a+','}); //輸出 12 345 678

1.用循環的方式實現(百度上淘來的)

    function formatNum(str){
        var newStr = "";
        var count = 0;

        if(str.indexOf(".")==-1){
            for(var i=str.length-1;i>=0;i--){
                if(count % 3 == 0 && count != 0){
                    newStr = str.charAt(i) + "," + newStr;
                }else{
                    newStr = str.charAt(i) + newStr;
                }
                count++;
            }
            str = newStr + ".00"; //自動補小數點后兩位
            console.log(str)
        }
        else
        {
            for(var i = str.indexOf(".")-1;i>=0;i--){
                if(count % 3 == 0 && count != 0){
                    newStr = str.charAt(i) + "," + newStr;  //碰到3的倍數則加上“,”號
                }else{
                    newStr = str.charAt(i) + newStr; //逐個字符相接起來
                }
                count++;
            }
            str = newStr + (str + "00").substr((str + "00").indexOf("."),3);
            console.log(str)
        }
    }

    formatNum('13213.24');  //輸出13,213.34
    formatNum('132134.2');    //輸出132,134.20
    formatNum('132134');    //輸出132,134.00
formatNum('132134.236');    //輸出132,134.236

2.使用正則(比較不足的是還是得自己去判斷小數點后面的位數,有更智能的正則請通知我~)

function regexNum(str){
    var regex = /(\d)(?=(\d\d\d)+(?!\d))/g;

    if(str.indexOf(".") == -1){

        str= str.replace(regex,',') + '.00';
        console.log(str)

    }else{
        var newStr = str.split('.');
        var str_2 = newStr[0].replace(regex,',');

        if(newStr[1].length <= 1){ 
            //小數點后只有一位時
            str_2 = str_2 + '.' + newStr[1] +'0';
            console.log(str_2)

        }else if(newStr[1].length > 1){ 
            //小數點后兩位以上時
            var decimals = newStr[1].substr(0,2);
            var srt_3 = str_2 + '.' + decimals;
            console.log(srt_3)
        }
    }
};
regexNum('23424224'); //輸出2,42,224.00 
regexNum('23424224.2'); //輸出2,42,224.20
regexNum('23424224.22'); //輸出2,42,224.22
regexNum('23424224.233'); //輸出2,42,224.23 

 


文章列表


不含病毒。www.avast.com
arrow
arrow
    全站熱搜
    創作者介紹
    創作者 大師兄 的頭像
    大師兄

    IT工程師數位筆記本

    大師兄 發表在 痞客邦 留言(0) 人氣()