数字格式化 1234567890 转换 1,234,567,890(千分位),各种骚操作

1、普通版

// 数字格式化 1234567890 --> 1,234,567,890
function formatNumber(str){
    var arr = [];
    var count = str.length;
    while(count>=3){
        arr.unshift(str.slice(count - 3, count));
        count -= 3;
    }
    // 如果是不是3的倍数就另外追加到上去
    str.length % 3 && arr.unshift(str.slice(0, str.length % 3));
    return arr.toString();
}
formatNumber('1234567890')

复制代码

2、进阶版

// 2、进阶版
function formatNumber(str){
    return str.split("").reverse().reduce((prev,next,index) => {
        return ((index%3)? next: (next+',')) + prev;
    })
}
formatNumber("1234567890");复制代码

3、正则版

function formatNumber(str){    return str.replace(/(?!^)(?=(\d{3})+$)/g,',')}formatNumber("1234567890");复制代码

我们来看看正则的分析:

(1)/(?!^)(?=(d{3})+b)/g:匹配的这个位置不能是开头(?!^)

(2)(d{3})+:必须是1个或者多个的3个连续数字

4、API版本

(1234567890).toLocaleString('en-us');(1234567890).toLocaleString();1234567890..toLocaleString();复制代码

你可能还不知道 JavaScript 的 toLocaleString 还可以这么玩。

123456789..toLocaleString('zh-hans-cn-u-nu-hanidec',{useGrouping: false}); //"一二三四五六七八九"
123456789..toLocaleString('zh-hans-cn-u-nu-hanidec',{useGrouping: true}); //"一二三,四五六,七八九"
new Date().toLocaleString('zh-hans-cn-u-nu-hanidec'); //"二〇一九/五/二九 下午三:一五:四〇"
复制代码


转载于:https://juejin.im/post/5d00a12f6fb9a07ecd3d54da

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
JS千分数字格式化是一种将数字以千分隔的形式呈现的方法。其中有多种实现方法,可以通过字符串的分割、拼接、遍历以及正则表达式等技巧来实现。这些方法可以帮助我们将数字中的每三添加一个逗号,以提高数字的可读性。 举例来说,我们可以使用正则表达式数字数补足为3的倍数,然后将其切割成每三个数字一个分组,再通过join方法添加逗号,最后移除补充的0。这种方法被称为懒人法,可以实现简洁高效的千分格式化。 另外,还有其他实现方法,比如使用递归、使用toLocaleString()方法等等。每种方法都有其适用的场景和优缺点,可以根据具体需求选择相应的方法来进行千分数字格式化。 总结而言,JS千分数字格式化是一种通过添加逗号将数字以千分隔的方式来提高数字可读性的方法。它可以通过多种实现方法来达到这个目的,包括字符串操作、遍历、正则表达式等。根据具体情况,选择合适的实现方法可以使代码更加简洁高效。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* [JS数字千分格式化实现方法总结](https://download.csdn.net/download/weixin_38612527/12985940)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_1"}}] [.reference_item style="max-width: 50%"] - *2* *3* [JS实现的4种数字格式化方法分享](https://blog.csdn.net/hzxOnlineOk/article/details/121752954)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_1"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值