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
相关推荐
lecepin1 小时前
AI Coding 资讯 2025-09-17
前端·javascript·面试
IT_陈寒1 小时前
React 18实战:7个被低估的Hooks技巧让你的开发效率提升50%
前端·人工智能·后端
树上有只程序猿1 小时前
终于有人把数据库讲明白了
前端
猩兵哥哥2 小时前
前端面向对象设计原则运用 - 策略模式
前端·javascript·vue.js
司宸2 小时前
Prompt设计实战指南:三大模板与进阶技巧
前端
RoyLin2 小时前
TypeScript设计模式:抽象工厂模式
前端·后端·typescript
华仔啊2 小时前
Vue3+CSS 实现的 3D 卡片动画,让你的网页瞬间高大上
前端·css
江城开朗的豌豆2 小时前
解密React虚拟DOM:我的高效渲染秘诀 🚀
前端·javascript·react.js
vivo互联网技术2 小时前
拥抱新一代 Web 3D 引擎,Three.js 项目快速升级 Galacean 指南
前端·three.js