JS实现货币格式化、货币繁体汉字化

/**
 * 货币格式化函数
 * 
 * @param num
 *            未格式化货币
 * @return 格式化货币:000,000.00
 */
function formatCurrency(num) {
	if (num === null || num === undefined || num === '') 
	{
		return "";
	}
	num = num.toString().replace(/\$|\,/g, '');  
	if( isNaN(num) )
	{
		num = "0";
	}
	sign = (num == (num = Math.abs(num) ) );
	num = Math.floor(num * 100 + 0.50000000001);
	cents = num % 100;
	num = Math.floor(num / 100).toString();
	if ( cents < 10 )
	{
		cents = "0" + cents;
	}
	for (var i = 0; i < Math.floor( (num.length - (1 + i) ) / 3); i++)
	{
		num = num.substring(0, num.length - (4 * i + 3) ) + ',' + num.substring(num.length - (4 * i + 3) );
	}
	return ( ( (sign)?'':'-')  + num + '.' + cents);
}

/**
 * 还原货币格式化函数
 * 
 * @param num
 *            格式化货币:000,000.00
 * @return 数字字符串
 */
function restoreFormatCurrency(num)
{
	var num1=num.replace(',', '').replace(/,/g, '');
	return num1;
}  


/** 数字金额大写转换(可以处理整数,小数,负数) */  
function digit_uppercase(n)   
{  
    var fraction = ['角', '分'];  
    var digit = ['零', '壹', '贰', '叁', '肆', '伍', '陆', '柒', '捌', '玖'];  
    var unit = [ ['元', '万', '亿'], ['', '拾', '佰', '仟']  ];  
    var head = n < 0? '欠': '';  
    n = Math.abs(n);  
  
    var s = '';  
  
    for (var i = 0; i < fraction.length; i++)   
    {  
        s += (digit[Math.floor(n * 10 * Math.pow(10, i)) % 10] + fraction[i]).replace(/零./, '');  
    }  
    s = s || '整';  
    n = Math.floor(n);  
  
    for (var i = 0; i < unit[0].length && n > 0; i++)   
    {  
        var p = '';  
        for (var j = 0; j < unit[1].length && n > 0; j++)   
        {  
            p = digit[n % 10] + unit[1][j] + p;  
            n = Math.floor(n / 10);  
        }  
        s = p.replace(/(零.)*零$/, '').replace(/^$/, '零')  + unit[0][i] + s;  
    }  
    return head + s.replace(/(零.)*零元/, '元').replace(/(零.)+/g, '零').replace(/^整$/, '零元整');  
} 

显示:

  1.  /** 整数测试数据   
  2.     alert(digit_uppercase(0));          // 零元整  
  3.     alert(digit_uppercase(123));        // 壹佰贰拾叁元整  
  4.     alert(digit_uppercase(1000000));    // 壹佰万元整  
  5.     alert(digit_uppercase(100000001));  // 壹亿零壹元整  
  6.     alert(digit_uppercase(1000000000)); // 壹拾亿元整  
  7.     alert(digit_uppercase(1234567890)); // 壹拾贰亿叁仟肆佰伍拾陆万柒仟捌佰玖拾元整  
  8.     alert(digit_uppercase(1001100101)); // 壹拾亿零壹佰壹拾万零壹佰零壹元整  
  9.     alert(digit_uppercase(110101010));  // 壹亿壹仟零壹拾万壹仟零壹拾元整  
  10.       
  11.     */  
  12.       
  13.     /** 小数测试数据   
  14.     alert(digit_uppercase(0.12));          // 壹角贰分  
  15.     alert(digit_uppercase(123.34));        // 壹佰贰拾叁元叁角肆分  
  16.     alert(digit_uppercase(1000000.56));    // 壹佰万元伍角陆分  
  17.     alert(digit_uppercase(100000001.78));  // 壹亿零壹元柒角捌分  
  18.     alert(digit_uppercase(1000000000.90)); // 壹拾亿元玖角  
  19.     alert(digit_uppercase(1234567890.03)); // 壹拾贰亿叁仟肆佰伍拾陆万柒仟捌佰玖拾元叁分  
  20.     alert(digit_uppercase(1001100101.00)); // 壹拾亿零壹佰壹拾万零壹佰零壹元整  
  21.     alert(digit_uppercase(110101010.10));  // 壹亿壹仟零壹拾万壹仟零壹拾元壹角  
  22.       
  23.     */  
  24.       
  25.     /** 负数(欠款)测试数据   
  26.     alert(digit_uppercase(-0.12));          // 欠壹角贰分  
  27.     alert(digit_uppercase(-123.34));        // 欠壹佰贰拾叁元叁角肆分  
  28.     alert(digit_uppercase(-1000000.56));    // 欠壹佰万元伍角陆分  
  29.     alert(digit_uppercase(-100000001.78));  // 欠壹亿零壹元柒角捌分  
  30.     alert(digit_uppercase(-1000000000.90)); // 欠壹拾亿元玖角  
  31.     alert(digit_uppercase(-1234567890.03)); // 欠壹拾贰亿叁仟肆佰伍拾陆万柒仟捌佰玖拾元叁分  
  32.     alert(digit_uppercase(-1001100101.00)); // 欠壹拾亿零壹佰壹拾万零壹佰零壹元整  
  33.     alert(digit_uppercase(-110101010.10));  // 欠壹亿壹仟零壹拾万壹仟零壹拾元壹角  
  34.        
  35.      */  


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值