js正则表达式将一个字符串拆分成3个一组,每组添加,

javascript 复制代码
let a='123456789.9876543210'

a.toString().replace(/\B(?=(\d{3})+(?!\d))/g, ",")//输出结果:'123,456,789.9,876,543,210'
  1. num.toString(): 将数字 num 转换为字符串。

  2. .replace(/\B(?=(\d{3})+(?!\d))/g, ','):

    • .replace() 是字符串对象的方法,用于替换匹配的字符串。
    • / \B(?=(\d{3})+(?!\d))/g 是一个新的正则表达式。
      • \B: 匹配一个非单词边界,确保我们不在数字的开头插入逗号。
      • (?=(\d{3})+(?!\d)): 正向预查,匹配之后跟着一组三个数字(这个组可以重复多次),但是不能再有数字。
      • /g: 全局匹配,替换所有匹配而不仅仅是第一个。
    • ',': 替换为逗号。

假设 num 的值为 1234567.89

  • num.toString() 将其转换为字符串 "1234567.89"
  • .replace(/\B(?=(\d{3})+(?!\d))/g, ',')
    • 正则表达式在字符串中查找每个非单词边界的位置。
    • 当它找到一个位置,该位置后面跟着一组三个数字(或者是字符串的结尾),就在这个位置插入一个逗号。
    • 所以,1234567.89 被替换为 1,234,567.89

这样修改后的代码能够正确处理包含小数位的数字,并在适当的位置插入千位分隔符。

相关推荐
我叫汪枫16 小时前
前端物理引擎库推荐 - 让你的网页动起来!
前端
雾恋21 小时前
最近一年的感悟
前端·javascript·程序员
华仔啊21 小时前
Vue3 的 ref 和 reactive 到底用哪个?90% 的开发者都选错了
javascript·vue.js
A黄俊辉A21 小时前
axios+ts封装
开发语言·前端·javascript
F_D_Z1 天前
【SQL】指定日期的产品价格
数据库·sql·mysql
小李小李不讲道理1 天前
「Ant Design 组件库探索」四:Input组件
前端·javascript·react.js
程序员在线炒粉8元1份顺丰包邮送可乐1 天前
Docker 部署生产环境可用的 MySQL 主从架构
mysql·docker·架构
连合机器人1 天前
晨曦中的守望者:当科技为景区赋予温度
java·前端·科技
郑板桥301 天前
tua-body-scroll-lock踩坑记录
前端·javascript
麦聪聊数据1 天前
如何使用 QuickAPI 快速连接 MySQL 数据库并发布 RESTful API
数据库·sql·mysql·restful·数据服务