javascript中如何将长数字格式化,如"10000"变成"10,000"或"10 000"

在做一个和金融有关的系统,里面牵涉到金额数字这些东西,希望能在格式化后更适合阅读。

阅读 29.9k
6 个回答

答案更新:
今天看到有人赞了这个答案,老问题还有人在看也是受宠若惊,就更新下答案吧。
最近这些日子我也碰到了相关的问题,发现其实自带的 Number 就能帮助我们解决这个问题。使用

(10000).toLocaleString('en-US');

就可以帮我们按照三位数加上逗号,如果使用

(10000).toLocaleString('en-US', {style: 'currency', currency: 'USD'});

还可以帮我们加上 $ 前缀,简单方便。
更多使用方法可以参考 https://developer.mozilla.org... ,另外这个 IE11 才支持哦~


我是老答案

PHP里头有number_format函数可以对数字进行格式化,然后我找了一个JS版的number_format函数,感觉还不错。
但是我觉得这个太强大了,只是要加个逗号什么的没必要,就自己写了一个。JS新手,用PHP的思路写的JS,可能不是最好的,不过确定是可以用的,希望能帮到你。

function number_format(num, format) {
        if(num.length <= 3) return num;
        if (num.length % 3 == 0) {
                count = num.length/3;
        }else{
                count = (num.length-num.length%3)/3;
        }
        var text = '';
        for(i=0;i<count;i++) {
                if((count-i-1)*3+num.length%3!=0) {
                        text=format+num.slice((count-i-1)*3+num.length%3,(count-i-1)*3+num.length%3+3)+text;
                }else {
                        text=num.slice((count-i-1)*3+num.length%3,(count-i-1)*3+num.length%3+3)+text;
                }
        }
        return num.slice(0,num.length % 3)+text;
}

在不少地方看过这个问题,没有看到特别满意的答案。
主要原因:

  • 我不希望因为一个函数去引入一个js文件
  • 没有考虑特殊的数字,比如.5, 5.
  • 没有考虑小数点
  • 没有考虑可能传入非法数值
  • 不够简洁

在此分享一下我的答案,全当抛砖引玉,不足的地方欢迎指正。

function formatNumber(num, precision, separator) {
    var parts;
    // 判断是否为数字
    if (!isNaN(parseFloat(num)) && isFinite(num)) {
        // 把类似 .5, 5. 之类的数据转化成0.5, 5, 为数据精度处理做准, 至于为什么
        // 不在判断中直接写 if (!isNaN(num = parseFloat(num)) && isFinite(num))
        // 是因为parseFloat有一个奇怪的精度问题, 比如 parseFloat(12312312.1234567119)
        // 的值变成了 12312312.123456713
        num = Number(num);
        // 处理小数点位数
        num = (typeof precision !== 'undefined' ? num.toFixed(precision) : num).toString();
        // 分离数字的小数部分和整数部分
        parts = num.split('.');
        // 整数部分加[separator]分隔, 借用一个著名的正则表达式
        parts[0] = parts[0].toString().replace(/(\d)(?=(\d{3})+(?!\d))/g, '$1' + (separator || ','));

        return parts.join('.');
    }
    return NaN;
}

测试:

formatNumber(10000)
"10,000"
formatNumber(10000, 2)
"10,000.00"
formatNumber(10000.123456, 2)
"10,000.12"
formatNumber(10000.123456, 2, ' ')
"10 000.12"
formatNumber(.123456, 2, ' ')
"0.12"
formatNumber(56., 2, ' ')
"56.00"
formatNumber(56., 0, ' ')
"56"
formatNumber('56.')
"56"
formatNumber('56.a')
NaN
新手上路,请多包涵

用正则表达式匹配

比如:

result = "1234567890".replace(/\d+?(?=(?:\d{3})+$)/img, "$& ");
function numFormat(num) {
        var c = (num.toString().indexOf ('.') !== -1) ? num.toLocaleString() : num.toString().replace(/(\d)(?=(?:\d{3})+$)/g, '$1,');
        return c;
    }

参考:
https://blog.csdn.net/lihchwe...

撰写回答
你尚未登录,登录后可以
  • 和开发者交流问题的细节
  • 关注并接收问题和回答的更新提醒
  • 参与内容的编辑和改进,让解决方法与时俱进
推荐问题
宣传栏