JavaScript实现金额的大小写转换

本文介绍了一个使用JavaScript实现的金额大小写转换程序。该程序通过HTML表单接收用户输入的小写金额,并利用JavaScript进行转换,最终将大写金额显示在表单中。

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

        JavaScript实现金额的大小写转换

              用dw软件画出表单,加入转换(普通按钮)和重置(reset按钮)

<%@ page language="java" contentType="text/html; charset=UTF-8"

    pageEncoding="UTF-8"%>
<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
<title>数字大小写转换</title>
<script type="text/javascript">
    function zhuanhuan() {
var s=document.getElementById("xxie");
var s1=document.getElementById("dxie");
var str=s.value;
var str1=s1.value;
var String1 = "零壹贰叁肆伍陆柒捌玖"; 
var String2 = "万仟佰拾亿仟佰拾万仟佰拾元角分"; 
var len=str.length; 
var Ch1; 
var Ch2; 
var nZero=0; 
var String3;
if(len>15){  
alert("超出计算范围");  
return "";  
}  
if (str==0){  
str1 = "零元整";
s1.value=str1;
return str1;  
}  
String2 = String2.substr(String2.length-len, len); // 取出对应位数的STRING2的值  
for(var i=0; i<len; i++){  
String3 = parseInt(str.substr(i, 1),10); // 取出需转换的某一位的值  
if ( i != (len - 3) && i != (len - 7) && i != (len - 11) && i !=(len - 15) ){  
if ( String3 == 0 ){  
Ch1 = "";  
Ch2 = "";  
nZero = nZero + 1;  
}  
else if ( String3 != 0 && nZero != 0 ){  
Ch1 = "零" + String1.substr(String3, 1);  
Ch2 = String2.substr(i, 1);  
nZero = 0;  
}  
else{  
Ch1 = String1.substr(String3, 1);  
Ch2 = String2.substr(i, 1);  
nZero = 0;  
}  
}  
else{ // 该位是万亿,亿,万,元位等关键位  
if( String3 != 0 && nZero != 0 ){  
Ch1 = "零" + String1.substr(String3, 1);  
Ch2 = String2.substr(i, 1);  
nZero = 0;  
}  
else if ( String3 != 0 && nZero == 0 ){  
Ch1 = String1.substr(String3, 1);  
Ch2 = String2.substr(i, 1);  
nZero = 0;  
}  
else if( String3 == 0 && nZero >= 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);  
}  
}  
str1 = str1 + Ch1 + Ch2;  
}  
if ( String3 == 0 ){ // 最后一位(分)为0时,加上“整”  
str1 = str1 + "整";  
}  
s1.value=str1;
return str1;  
}  
</script>
</head>
<body>
<form action="" method="post" enctype="multipart/form-data" name="form1" id="form1">
  <p>金额转换</p>
  <p>&nbsp;</p>
  <p>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;
  请输入小写金额:<br />
    &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;
    <input type="text" name="xxie" id="xxie" />
  </p>
  <p>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;
  转换后的大写金额:<br/>
  &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;
  <textarea name="dxie" id="dxie" cols="45" rows="5"></textarea>
  </p>
  <p>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;
    <input type="button" name="zhuan" id="zhuan" value="转换" onclick="zhuanhuan();"/>
     &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;
     <input type="reset" name="cshu" id="cshu" value="重新输入"/>
  </p>
</form>
</body>
</html>
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、付费专栏及课程。

余额充值