废话不多说,直接上代码:
function isNumber(obj){
return (typeof obj==‘number’)&&obj.constructorNumber;
}
function isString(str){
return (typeof str’string’)&&str.constructor==String;
}
function seprator(str){
var result = [];
for(var i=0;i<str.length;i+=3){
result.push(str.slice(i,i+3));
}
result=result.map(item=>item.toString().replace(/\D/g,’’))
result=result.toString()
return result
}
var str=‘13254896327812’
function sepratorThousand(str,{prefix=‘¥’,suffix=’’,persist=0}={}){
var resStr=’’
if(isNumber(str)){
str=str.toString()
}
var reg=new RegExp(/^\d+.\d+$/)
if(reg.test(str)){
resStr=str.split(’.’)[0]
}else{
resStr=str
}
var len=resStr.length;
if(len%3>=1&&len%3<3){
var newStr=resStr.substr(len%3)
resStr=newStr.split(’’)
result=seprator(resStr)
result=str.substr(0,len%3)+’,’+result
}else{
resStr=resStr.split(’’)
result=seprator(resStr)
}
if(str.split(’.’)[1]){
result=result+’.’+str.split(’.’)[1]
}
return prefix+result+(suffix?suffix:’’)+(persist>0&&!str.split(’.’)[1]?(’.’+_.repeat(0,persist)):’’)
}
console.log(’---------’,sepratorThousand(str))
console.log(’---------’,sepratorThousand(‘1245849.33’))
console.log(’------------’,sepratorThousand(1245849.33))
console.log(’---------------’,sepratorThousand(1245849,{persist:1}))
console.log(’-----------------’,sepratorThousand(1245849.33,{persist:2}))
console.log(’-----------------’,sepratorThousand(1245849,{persist:2}))
原生js+正则+es6语法实现 千位分隔符
最新推荐文章于 2023-12-08 23:20:17 发布
这篇博客主要展示了JavaScript函数,用于检查输入是否为数字、字符串,并进行数字分隔。`sepratorThousand`函数将数字按每三位添加逗号分隔,同时支持自定义前缀、后缀和小数位数。示例中,该函数成功处理了不同类型的数字输入,并实现了千位分隔和小数位保留。
摘要由CSDN通过智能技术生成