Javascript将数值转换为金额格式分隔千分位和自动增加小数点

在项目里碰到需要把类似'450000'的数字转换为会计记账所用的格式,'450,000.00',分隔千分位和小数点后不够两位数时自动补齐,已下记录几种实现的方式

ps:如果不考虑后面的小数点,最快捷的方法

"12345678".replace(/[0-9]+?(?=(?:([0-9]{3}))+$)/g,function(a){return a+','}); //输出 12 345 678

1.用循环的方式实现

if(str.indexOf(".")==-1){
for(var i=str.length-1;i>=0;i--){
if(count % 3 == 0 && count != 0){
newStr = str.charat(i) + "," + newStr;
}else{
newStr = str.charat(i) + newStr;
}
count++;
}
str = newStr + ".00"; //自动补小数点后两位
console.log(str)
}
else
{
for(var i = str.indexOf(".")-1;i>=0;i--){
if(count % 3 == 0 && count != 0){
newStr = str.charat(i) + "," + newStr; //碰到3的倍数则加上“,”号
}else{
newStr = str.charat(i) + newStr; //逐个字符相接起来
}
count++;
}
str = newStr + (str + "00").substr((str + "00").indexOf("."),3);
console.log(str)
}
}

formatNum('13213.24'); //输出13,213.34
formatNum('132134.2'); //输出132,134.20
formatNum('132134'); //输出132,134.00
formatNum('132134.236'); //输出132,134.236

2.使用正则

(比较不足的是还是得自己去判断小数点后面的位数,有更智能的正则请通知我~)

rush:js;"> function regexnum(str){ var regex = /(\d)(?=(\d\d\d)+(?!\d))/g;

if(str.indexOf(".") == -1){

str= str.replace(regex,',') + '.00';
console.log(str)

}else{
var newStr = str.split('.');
var str_2 = newStr[0].replace(regex,');

if(newStr[1].length <= 1){
//小数点后只有一位时
str_2 = str_2 + '.' + newStr[1] +'0';
console.log(str_2)

}else if(newStr[1].length > 1){
//小数点后两位以上时
var decimals = newStr[1].substr(0,2);
var srt_3 = str_2 + '.' + decimals;
console.log(srt_3)
}
}
};
regexnum('23424224'); //输出2,42,224.00
regexnum('23424224.2'); //输出2,224.20
regexnum('23424224.22'); //输出2,224.22
regexnum('23424224.233'); //输出2,224.23

以上就是本文的全部内容,了解更多JavaScript的语法,大家可以查看:《》、《》,也希望大家多多支持编程之家。

相关文章

前言 做过web项目开发的人对layer弹层组件肯定不陌生,作为l...
前言 前端表单校验是过滤无效数据、假数据、有毒数据的第一步...
前言 图片上传是web项目常见的需求,我基于之前的博客的代码...
前言 导出Excel文件这个功能,通常都是在后端实现返回前端一...
前言 众所周知,js是单线程的,从上往下,从左往右依次执行,...
前言 项目开发中,我们可能会碰到这样的需求:select标签,禁...