最新文章专题视频专题问答1问答10问答100问答1000问答2000关键字专题1关键字专题50关键字专题500关键字专题1500TAG最新视频文章推荐1 推荐3 推荐5 推荐7 推荐9 推荐11 推荐13 推荐15 推荐17 推荐19 推荐21 推荐23 推荐25 推荐27 推荐29 推荐31 推荐33 推荐35 推荐37视频文章20视频文章30视频文章40视频文章50视频文章60 视频文章70视频文章80视频文章90视频文章100视频文章120视频文章140 视频2关键字专题关键字专题tag2tag3文章专题文章专题2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章专题3
当前位置: 首页 - 科技 - 知识百科 - 正文

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

来源:动视网 责编:小采 时间:2020-11-27 20:27:02
文档

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

Javascript将数值转换为金额格式(分隔千分位和自动增加小数点):在项目里碰到需要把类似'450000'的数字转换为会计记账所用的格式,'450,000.00',分隔千分位和小数点后不够两位数时自动补齐,已下记录几种实现的方式ps:如果不考虑后面的小数点,最快捷的方法:"12345678".r
推荐度:
导读Javascript将数值转换为金额格式(分隔千分位和自动增加小数点):在项目里碰到需要把类似'450000'的数字转换为会计记账所用的格式,'450,000.00',分隔千分位和小数点后不够两位数时自动补齐,已下记录几种实现的方式ps:如果不考虑后面的小数点,最快捷的方法:"12345678".r


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

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

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

1.用循环的方式实现

function formatNum(str){
 var newStr = "";
 var count = 0;
 
 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.使用正则(比较不足的是还是得自己去判断小数点后面的位数,有更智能的正则请通知我~)

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,42,224.20 regexNum('23424224.22'); //输出2,42,224.22 regexNum('23424224.233'); //输出2,42,224.23

文档

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

Javascript将数值转换为金额格式(分隔千分位和自动增加小数点):在项目里碰到需要把类似'450000'的数字转换为会计记账所用的格式,'450,000.00',分隔千分位和小数点后不够两位数时自动补齐,已下记录几种实现的方式ps:如果不考虑后面的小数点,最快捷的方法:"12345678".r
推荐度:
  • 热门焦点

最新推荐

猜你喜欢

热门推荐

专题
Top