js中常见的金额转换方式

1.js转换金钱为中文单位元、万元、亿元、万亿

javascript 复制代码
function unitConvert(num) {
   var moneyUnits = ["元", "万元", "亿元", "万亿"]
   var dividend = 10000;
   var curentNum = num;
   //转换数字
   var curentUnit = moneyUnits[0];
   //转换单位
    for (var i = 0; i <4; i++) {
           curentUnit = moneyUnits[i]
           if(strNumSize(curentNum)<5){
           break;
       }
       curentNum = curentNum / dividend
}
var m = {num: 0, unit: ""}
      m.num = curentNum.toFixed(2)
      m.unit = curentUnit;
      return m;
     }
 
function strNumSize(tempNum){
      var stringNum = tempNum.toString()
      var index = stringNum.indexOf(".")
      var newNum = stringNum;
      if(index!=-1){
          newNum = stringNum.substring(0,index)
       }
       return newNum.length
}
 
//调用并且得到返回值
var data=unitConvert(100000);
console.log(data.num+data.unit) //10.00万元

2. 金额格式化处理

javascript 复制代码
 // 金额 格式化
function  outputmoney(value) {  
      if (!value && value !== 0) return '-';
      var intPart = Number(value) | 0; //获取整数部分
      var intPartFormat = intPart.toString().replace(/(\d)(?=(?:\d{3})+$)/g, '$1,'); //将整数部分逢三一断
  
      var floatPart = ".00"; //预定义小数部分
      var value2Array = value.toString().split(".");
  
      //=2表示数据有小数位
      if (value2Array.length == 2) {
          floatPart = value2Array[1].toString(); //拿到小数部分
  
          if (floatPart.length == 1) { //补0,实际上用不着
              return intPartFormat + "." + floatPart + '0';
          } else {
              return intPartFormat + "." + floatPart;
          }
      } else {
          return intPartFormat + floatPart;
      }
    }
console.log(outputmoney(1111)); //1,111.00
console.log(outputmoney(11.56812111111)); //11.56812111111

// style 格式化时使用的样式
// "decimal"表示纯数字格式 , "currency"表示货币格式, 和"percent"表示百分比格式; 默认值是 "decimal"

// currency  在货币格式化中使用的货币符号
// "USD" 表示美元, "EUR" 表示欧元, "CNY"是人民币
// 没有默认值,如果样式是"currency",必须提供货币属性. minimumFractionDigits
// 使用的小数位数的最小数目.可能的值是从0到20;默认为普通的数字和百分比格式为0;
// 格式化金额(后面两位小数会四舍五入)
function  moneyFormats(value){
		let a=Number(value);  //转为数字格式
		
		let b=a.toLocaleString('zh', { style: 'currency', currency: 'CNY' });
		
		return b;
	}

console.log(moneyFormats(23.547))    //¥23.55
javascript 复制代码
function formatMoney(s, type) {  
    if (/[^0-9\.]/.test(s))  
        return "0";  
    if (s == null || s == "")  
        return "0";  
    s = s.toString().replace(/^(\d*)$/, "$1.");  
    s = (s + "00").replace(/(\d*\.\d\d)\d*/, "$1");  
    s = s.replace(".", ",");  
    var re = /(\d)(\d{3},)/;  
    while (re.test(s))  
        s = s.replace(re, "$1,$2");  
    s = s.replace(/,(\d\d)$/, ".$1");  
    if (type == 0) {// 不带小数位(默认是有小数位)
        var a = s.split(".");  
        if (a[1] == "00") {  
            s = a[0];  
        }  
    }  
    return s;  
}  
console.log(formatMoney('11110.335',3)); // 11,110.33
相关推荐
烛阴几秒前
void 0 的奥秘:解锁 JavaScript 中 undefined 的正确打开方式
前端·javascript
中微子7 分钟前
JavaScript 事件与 React 合成事件完全指南:从入门到精通
前端
Hexene...16 分钟前
【前端Vue】如何实现echarts图表根据父元素宽度自适应大小
前端·vue.js·echarts
初遇你时动了情17 分钟前
腾讯地图 vue3 使用 封装 地图组件
javascript·vue.js·腾讯地图
dssxyz21 分钟前
uniapp打包微信小程序主包过大问题_uniapp 微信小程序时主包太大和vendor.js过大
javascript·微信小程序·uni-app
天天扭码1 小时前
《很全面的前端面试题》——HTML篇
前端·面试·html
xw51 小时前
我犯了错,我于是为我的uni-app项目引入环境标志
前端·uni-app
!win !1 小时前
被老板怼后,我为uni-app项目引入环境标志
前端·小程序·uni-app
Burt1 小时前
tsdown vs tsup, 豆包回答一坨屎,还是google AI厉害
前端
群联云防护小杜2 小时前
构建分布式高防架构实现业务零中断
前端·网络·分布式·tcp/ip·安全·游戏·架构