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

作者:沫鱼 时间:2023-08-18 10:31:11 

在项目里碰到需要把类似'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,数值,金额
0
投稿

猜你喜欢

  • Oracle AS关键字 提示错误

    2011-04-18 12:42:00
  • 用好Frontpage中的各种回车

    2008-02-21 14:33:00
  • 不错的广告定位效果代码

    2009-06-05 18:51:00
  • 利用phpExcel实现Excel数据的导入导出(全步骤详细解析)

    2023-06-22 02:56:42
  • 如何正确处理数据库中的Null

    2007-09-30 19:41:00
  • asp.net(c#)实现从sqlserver存取二进制图片的代码

    2023-06-26 21:48:03
  • 教你精确编写高质量高性能的MySQL语法

    2009-01-14 12:57:00
  • SQL点滴24 监测表的变化

    2011-09-30 11:38:41
  • FSO中的SubFolders 属性介绍

    2008-01-05 13:57:00
  • SQL 2008 FileStream数据类型

    2008-10-28 21:07:00
  • RHEL下架设MYSQL集群

    2008-12-24 16:05:00
  • AJAX无刷新验证用户名是否存在

    2007-08-10 10:07:00
  • 解决缩小图标变样问题

    2007-10-08 19:13:00
  • ASP 一次下载网页中的所有资源

    2008-04-18 13:04:00
  • Linux下C连接MySQL出现错误解决一例

    2008-12-29 13:17:00
  • fso怎样判断一个盘上是否有文件

    2007-09-26 12:35:00
  • 网马解密大讲堂——网马解密中级篇(Eval篇)

    2009-09-16 16:04:00
  • 使用SpringBoot + Redis 实现接口限流的方式

    2023-07-11 00:06:49
  • Python实现矩阵加法和乘法的方法分析

    2023-07-30 09:39:06
  • Javascript特效--划过放大的列表

    2008-03-21 12:18:00
  • asp之家 网络编程 m.aspxhome.com