1.正则匹配
function _comma(number) {
// 补全代码
let str = number.toString();
return str.replace(/(\d)(?=(?:\d{3})+$)/g, '$1,');
}
千位符正则解析:replace(/\d(?=(?:\d{3})+\b)/g, '$&,')
查找以\d为开头,以\b为结束(即"."的前面,这点我是到最后面才理解到的),中间 至少出现一次\d{3}的匹配
红色是开头\d,灰色是\d{3}+
第一次匹配到 1 234567890.012
第二次匹配到1234567890.012
第三次匹配到1234567890.012
然后在匹配到的数字后面加个',', 变成 1,2 34,567,890 .012
但是这里有几个难点要理解?=、?:和\b
?=是正向预匹配,即不会让?=后面的内容被匹配出来,这里的作用是不让\d{3}+被替换掉
?: 是非捕获性匹配,它使匹配不缓存起来,这点我要另起文章写,去掉了也不影响正确结果
\b是单词分界符,这个才是重点,去掉了会变成 1,2, 3,4,5,6,7,890 .012
因为少了\b限定,它不会以"."作结束标志,试理解下\d(?=\d{3}+),只要满足开头有一个\d后面至少有一个\d{3},它会这样匹配:
第一次: 1 234567890. 012
第二次:1234567890.012
第三次