js 金额大写

本文介绍了如何使用JavaScript将数字金额转换为大写的中文格式,包括整数和小数部分,实现了金额之间的空格间隔。文章针对split(".")处理小数部分的问题进行了探讨,并提供了改进的代码示例。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

 var rmbAmount = 356.400;
 var rmbAmount_ZH = "";//大写金额
 //分离整数位与小数位
 var rmbAmountArr = rmbAmount.toString().split(".");
 var inter = rmbAmountArr[0].split("");
 var decimal = rmbAmountArr[1].split("");
 //汉字的数字及单位
 var cnNums = new Array('零', '壹', '贰', '叁', '肆', '伍', '陆', '柒', '捌', '玖');
 var cnIntRadice = new Array('仟','佰','拾','万','仟','佰','拾','圆');
 var cnDecUnits = new Array('角','分','厘');
 //金额单位数组下标基准
 var benchmark = cnIntRadice.length - inter.length;
 //整数部分金额大写
 for(var i = 0; i < inter.length; i++){
	 rmbAmount_ZH = rmbAmount_ZH + cnNums[inter[i]] + " ";//金额
	 rmbAmount_ZH = rmbAmount_ZH + cnIntRadice[benchmark+i] + " ";//金额单位 
 }
 //小数部分金额大写
 for(var i = 0; i < decimal.length; i++){
     rmbAmount_ZH = rmbAmount_ZH + cnNums[decimal[i]] + " ";//金额
     rmbAmount_ZH = rmbAmount_ZH + cnDecUnits[i] + " ";//金额单位 
 }

最终效果就是金额大写,且间隔一个空格,下图为新建html中script中复制该代码的alert,原有运行环境是有“零分零厘”的,问题出在split(".")上,暂不处理
在这里插入图片描述
改进版***

var amountTotal = 0.00;
			for (var i = 0; i < vm.detailList.length; i++) {
				var amount = vm.detailList[i].gatheringAmountDetail;
				amountTotal = (Number(amountTotal) + Number(amount)).toFixed(2);
			}
			//修改小写金额
			vm.amountTotal = amountTotal;
//			$("#amountTotal").html = amountTotal;
			//修改大写金额
			if (vm.amountTotal == 0) {
				vm.rmbAmount_ZH = "零 元";//折合人民币金额
			} else {
				var rmbAmount_ZH = "";//大写金额
				//分离整数位与小数位
				var rmbAmountArr = vm.amountTotal.toString().split(".");
				var inter = rmbAmountArr[0];
				var decimal = rmbAmountArr[1] == undefined ? "0" : rmbAmountArr[1];
				//汉字的数字及单位
				var cnNums = new Array('零', '壹', '贰', '叁', '肆', '伍', '陆', '柒', '捌', '玖');
				var cnIntRadice = new Array('亿', '仟', '佰', '拾', '万', '仟', '佰', '拾', '圆');
				var cnDecUnits = new Array('角', '分', '厘');
				//金额单位数组下标基准
				var benchmark = cnIntRadice.length - inter.length;
				//整数部分金额大写
				var isZero = false;
				for (var i = 0; i < inter.length; i++) {
					if (inter[i] == 0) {
						if (isZero) {
							rmbAmount_ZH = rmbAmount_ZH.substr(0, rmbAmount_ZH.length - 2);
							if (cnIntRadice[benchmark + i] == "万" || cnIntRadice[benchmark + i] == "圆" || cnIntRadice[benchmark + i] == "亿") {
								rmbAmount_ZH = rmbAmount_ZH + cnIntRadice[benchmark + i] + " ";
								isZero = false;
							} else {
								rmbAmount_ZH = rmbAmount_ZH + "零 ";
							}
						} else {
							if (cnIntRadice[benchmark + i] == "万" || cnIntRadice[benchmark + i] == "圆" || cnIntRadice[benchmark + i] == "亿") {
								rmbAmount_ZH = rmbAmount_ZH + cnIntRadice[benchmark + i] + " ";
								isZero = false;
							} else {
								rmbAmount_ZH = rmbAmount_ZH + "零 ";
								isZero = true;
							}
						}
					} else {
						rmbAmount_ZH = rmbAmount_ZH + cnNums[inter[i]] + " ";
						rmbAmount_ZH = rmbAmount_ZH + cnIntRadice[benchmark + i] + " ";
						isZero = false;
					}

				}
				//小数部分金额大写
				if (decimal == 0) {
					rmbAmount_ZH += "整 ";
				} else {
					for (var i = 0; i < decimal.length; i++) {
						if (decimal[i] == 0) {
							rmbAmount_ZH = rmbAmount_ZH + "零 ";
						} else {
							rmbAmount_ZH = rmbAmount_ZH + cnNums[decimal[i]] + " ";
							rmbAmount_ZH = rmbAmount_ZH + cnDecUnits[i] + " ";
						}
					}
				}
				vm.amountTotal_ZH = rmbAmount_ZH;
			}

function CheckAlls(checked) { len = document.frmmain.elements.length; var i=0; for( i=0; i<len; i++) { if (document.frmmain.elements[i].name=='check_node_0') { if(document.frmmain.elements[i].disabled == false){ document.frmmain.elements[i].checked=(checked==true?true:false); } } } } document.onpropertychange= function() { var a= document.getElementById('field6163').value;//取小写金额的值 var numberValue=new String(Math.round(a*100)); // 数字金额 var String1 = "零壹贰叁肆伍陆柒捌玖"; // 汉字数字 var String2 = "万仟佰拾亿仟佰拾万仟佰拾元角分"; // 对应单位 var len=numberValue.length; // numberValue 的字符串长度 //alert(len); var Ch1; // 数字的汉语读法 var Ch2; // 数字位的汉字读法 var nZero=0; // 用来计算连续的零值的个数 var String3; // 指定位置的数值 { if(len>15){ alert("超出计算范围"); return fase; } if (numberValue==0){ chineseValue = "零元整"; } else { chineseValue=""; } String2 = String2.substr(String2.length-len, len); // 取出对应位数的STRING2的值 for(var i=0; i= 3 ){ Ch1 = ""; Ch2 = ""; nZero = nZero + 1; } else{ Ch1 = ""; Ch2 = String2.substr(i, 1); nZero = nZero + 1; } if( i == (len - 11) || i == (len - 3)){ // 如果该位是亿位或元位,则必须写上 Ch2 = String2.substr(i, 1); } } chineseValue =chineseValue +Ch1 + Ch2; } if ( String3 == 0 ){ // 最后一位(分)为0时,加上“整” chineseValue = chineseValue + "整"; } } //alert(chineseValue); document.getElementById('field6421').value=chineseValue; }
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值