JS 数字添加千位分隔符

本文介绍了如何使用正则表达式格式化数字,探讨了toLocaleString()方法的数字处理限制,并对比了newIntl.NumberFormat()方法在国际化的精确控制。适合理解数值格式转换的开发者阅读。
摘要由CSDN通过智能技术生成


一. 正则表达式

const reg = /(\d)(?=(\d{3})+$)/g;

// ❗❗❗使用String()把数字转换为字符串的优点在于null等情况不会报错
console.log(String(123456789).replace(reg, "$1,"));  // 123,456,789
// 支持整数,不支持小数
console.log(String(123456789.1315454).replace(reg, "$1,"));  // 123456789.1,315,454
console.log(String(1000).replace(reg, "$1,"));  // 1,000
console.log(String(null).replace(reg, "$1,"));  // null
console.log(String(undefined).replace(reg, "$1,"));  // undefined
console.log(String(NaN).replace(reg, "$1,"));  // NaN
console.log('😁😁😁😁😁😁');

二. toLocaleString()方法

// ❗❗❗必须是数字,如果是null或者undefined的话,会报错
console.log((123456789).toLocaleString('en-US'));  // 123,456,789
// 最多保留三位小数
console.log((123456789.1315454).toLocaleString('en-US'));  // 123,456,789.132
console.log('😁😁😁😁😁😁');

三. new Intl.NumberFormat()方法

console.log(new Intl.NumberFormat('en-US', {}).format(123456789.1315454));  
// 123,456,789.132
console.log(new Intl.NumberFormat('ja-JP', { style: 'currency', currency: 'JPY' }).format(123456789.1315454));  
// ¥123,456,789
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值