js 处理数字千分符,大小写转换。

先看下效果,



下面看下js实现

1.大小写转换,第一个参数是传入的值,第二个是小数位的个数。

function AmountInWords(dValue, maxDec)  {
		// 验证输入金额数值或数值字符串:
		//alert(dValue+"----"+maxDec);
		dValue = dValue.toString().replace(/,/g, ""); 
		dValue = dValue.replace(/^0+/, ""); // 金额数值转字符、移除逗号、移除前导零
		if (dValue == "") { return "零元整"; } // (错误:金额为空!)
  		else if (isNaN(dValue)) { return "错误:金额不是合法的数值!"; }  
  		var minus = ""; // 负数的符号“-”的大写:“负”字。可自定义字符,如“(负)”。
  		var CN_SYMBOL = ""; // 币种名称(如“人民币”,默认空)
  		if (dValue.length > 1){
  			if (dValue.indexOf('-') == 0) { dValue = dValue.replace("-", ""); minus = "负"; } // 处理负数符号“-”
  			if (dValue.indexOf('+') == 0) { dValue = dValue.replace("+", ""); } // 处理前导正数符号“+”(无实际意义)
		}
  		var vInt = "", vDec = ""; // 字符串:金额的整数部分、小数部分
  		var resAIW; // 字符串:要输出的结果
  		var parts; // 数组(整数部分.小数部分),length=1时则仅为整数。
  		var digits, radices, bigRadices, decimals; // 数组:数字(0~9——零~玖);基(十进制记数系统中每个数字位的基是10——拾,佰,仟);大基(万,亿,兆,京,垓,杼,穰,沟,涧,正);辅币(元以下,角/分/厘/毫/丝)。
  		var zeroCount; // 零计数
  		var i, p, d; // 循环因子;前一位数字;当前位数字。
  		var quotient, modulus; // 整数部分计算用:商数、模数。

  		// 金额数值转换为字符,分割整数部分和小数部分:整数、小数分开来搞(小数部分有可能四舍五入后对整数部分有进位)。
  		var NoneDecLen = (typeof(maxDec) == "undefined" || maxDec == null || Number(maxDec) < 0 || Number(maxDec) > 5); // 是否未指定有效小数位(true/false)
  		parts = dValue.split('.'); // 数组赋值:(整数部分.小数部分),Array的length=1则仅为整数。
  		if (parts.length > 1)  {
  			vInt = parts[0]; 
  			vDec = parts[1]; // 变量赋值:金额的整数部分、小数部分
  			if(NoneDecLen) { 
  				maxDec = vDec.length > 5 ? 5 : vDec.length; 
  			} 
  			// 未指定有效小数位参数值时,自动取实际小数位长但不超5。
  			var rDec = Number("0." + vDec);   
  			rDec *= Math.pow(10, maxDec); 
  			rDec = Math.round(Math.abs(rDec)); 
  			rDec /= Math.pow(10, maxDec); // 小数四舍五入
			var aIntDec = rDec.toString().split('.');
  			if(Number(aIntDec[0]) == 1) { 
  				vInt = (Number(vInt) + 1).toString(); 
  			} // 小数部分四舍五入后有可能向整数部分的个位进位(值1)
  			if(aIntDec.length > 1) { 
  				vDec = aIntDec[1]; 
  			} else { vDec = ""; }
  		}else { 
  			vInt = dValue; vDec = ""; if(NoneDecLen) { maxDec = 0; } 
  		}  
  		if(vInt.length > 44) { return "错误:金额值太大了!整数位长【" + vInt.length.toString() + "】超过了上限——44位/千正/10^43(注:1正=1万涧=1亿亿亿亿亿,10^40)!"; }
    
  		// 准备各字符数组 Prepare the characters corresponding to the digits:
  		digits = new Array("零", "壹", "贰", "叁", "肆", "伍", "陆", "柒", "捌", "玖"); // 零~玖
  		radices = new Array("", "拾", "佰", "仟"); // 拾,佰,仟
  		bigRadices = new Array("", "万", "亿", "兆", "京", "垓", "杼", "穰" ,"沟", "涧", "正"); // 万,亿,兆,京,垓,杼,穰,沟,涧,正
  		decimals = new Array("角", "分", "厘", "毫", "丝"); // 角/分/厘/毫/丝
		resAIW = ""; // 开始处理
    
  		// 处理整数部分(如果有)
  		if (Number(vInt) > 0) {
			zeroCount = 0;
			for (i = 0; i < vInt.length; i++){
  				p = vInt.length - i - 1; d = vInt.substr(i, 1); quotient = p / 4; modulus = p % 4;
  				if (d == "0") { 
  					zeroCount++; 
  				}else {
  					if (zeroCount > 0) { resAIW += digits[0]; }
  					zeroCount = 0; resAIW += digits[Number(d)] + radices[modulus];
  				}
  				if (modulus == 0 && zeroCount < 4) { resAIW += bigRadices[quotient]; }
  			}
  			resAIW += "元";
  		}
  		// 处理小数部分(如果有)
  		for (i = 0; i < vDec.length; i++) { d = vDec.substr(i, 1); if (d != "0") { resAIW += digits[Number(d)] + decimals[i]; } }
    
  		// 处理结果
  		if (resAIW == "") { resAIW = "零" + "元"; } // 零元
  		if (vDec == "") { resAIW += "整"; } // ...元整
  		resAIW = CN_SYMBOL + minus + resAIW; // 人民币/负......元角分/整
  		return resAIW;
	} 
2.转化为带千分符格式。

 function comdify(n)
    {
    var n=n.replace(/,/g,"");
    var re=/\d{1,3}(?=(\d{3})+$)/g;
    var n1=n.replace(/^(\d+)((\.\d+)?)$/,function(s,s1,s2){return s1.replace(re,"$&,")+s2;});
    return n1;
    }



3.用法

<td align="left">
    <span id="jeOrbl"><font color="red">* </font>金额(<span jwcid="@Insert" value="ognl:@com.zzxy.common.util.CodeCacheUtil@getNameByDmbz('','HBBZ',xm_zbxm.bz)"/>):</span>
      <input class="TextStyle" value="ognl:xm_sfbz.je" format="#,##0.00" jwcid="jeid@xylib:TextField" οnfοcusοut="numToChina(this)" οnkeyup="javascript:showDx(this)"/>
      <font id="jedx"></font>
    </td>


4.调用的numToChina()


function numToChina(obj1){
   		var obj=jQuery(obj1);
   		obj.val(comdify(obj.val()));
	   	document.getElementById('jedx').innerText = (obj.val()==''?'':AmountInWords(obj.val())); 		
   	}

5大工搞成,希望小伙伴们,有疑问的地方一起讨论讨论。



  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值