js实现人民币大写金额形式转换


Posted in Javascript onApril 27, 2016

本文实例为大家分享了js实现金额转大写的相关代码,供大家参考,具体内容如下

function convertCurrency(num) { //转成人民币大写金额形式
  var str1 = '零壹贰叁肆伍陆柒捌玖'; //0-9所对应的汉字
  var str2 = '万仟佰拾亿仟佰拾万仟佰拾元角分'; //数字位所对应的汉字
  var str3; //从原num值中取出的值
  var str4; //数字的字符串形式
  var str5 = ''; //人民币大写金额形式
  var i; //循环变量
  var j; //num的值乘以100的字符串长度
  var ch1; //数字的汉语读法
  var ch2; //数字位的汉字读法
  var nzero = 0; //用来计算连续的零值是几个
  num = Math.abs(num).toFixed(2); //将num取绝对值并四舍五入取2位小数
  str4 = (num * 100).toFixed(0).toString(); //将num乘100并转换成字符串形式
  j = str4.length; //找出最高位
  if (j > 15) {
    return '溢出';
  }
  str2 = str2.substr(15 - j); //取出对应位数的str2的值。如:200.55,j为5所以str2=佰拾元角分
  //循环取出每一位需要转换的值
  for (i = 0; i str3 = str4.substr(i, 1); //取出需转换的某一位的值
    if (i != (j - 3) && i != (j - 7) && i != (j - 11) && i != (j - 15)) { //当所取位数不为元、万、亿、万亿上的数字时
      if (str3 == '0') {
        ch1 = '';
        ch2 = '';
        nzero = nzero + 1;
      } else {
        if (str3 != '0' && nzero != 0) {
          ch1 = '零' + str1.substr(str3 * 1, 1);
          ch2 = str2.substr(i, 1);
          nzero = 0;
        } else {
          ch1 = str1.substr(str3 * 1, 1);
          ch2 = str2.substr(i, 1);
          nzero = 0;
        }
      }
    } else { //该位是万亿,亿,万,元位等关键位
      if (str3 != '0' && nzero != 0) {
        ch1 = "零" + str1.substr(str3 * 1, 1);
        ch2 = str2.substr(i, 1);
        nzero = 0;
      } else {
        if (str3 != '0' && nzero == 0) {
          ch1 = str1.substr(str3 * 1, 1);
          ch2 = str2.substr(i, 1);
          nzero = 0;
        } else {
          if (str3 == '0' && nzero >= 3) {
            ch1 = '';
            ch2 = '';
            nzero = nzero + 1;
          } else {
            if (j >= 11) {
              ch1 = '';
              nzero = nzero + 1;
            } else {
              ch1 = '';
              ch2 = str2.substr(i, 1);
              nzero = nzero + 1;
            }
          }
        }
      }
    } if (i == (j - 11) || i == (j - 3)) { //如果该位是亿位或元位,则必须写上
      ch2 = str2.substr(i, 1);
    }
    str5 = str5 + ch1 + ch2;
    if (i == j - 1 && str3 == '0') { //最后一位(分)为0时,加上“整”
      str5 = str5 + '整';
    }
  }
  if (num == 0) {
    str5 = '零元整';
  }
  if (str5.indexOf("分") == -1) {
    if (str5.indexOf("拾元零") > 0) {
      str5 = str5.replace("拾元零", "拾元");
    };
  }
  return str5;
}
 
function doConvert(m, n) {
  Ext.getCmp(m).on('change', function() {
    var objm = Ext.getCmp(m);
    var objn = Ext.getCmp(n);
    if (!(/^\d+(\.\d+)?$/.test(objm.getValue()))) {
      objn.setValue("");
    } else {
      var money = convertCurrency(objm.getValue());
      if (objm.getValue() == "") {
        objn.setValue("");
      } else {
        objn.setValue(money);
      }
    }
    var money = convertCurrency(objm.getValue());
    if (money.indexOf("拾元零") > 0) {
      if (money.indexOf("分") == -1) {
        objn.setValue(money.replace("拾元零", "拾元"));
      }
    };
  });
}

以上就是本文的全部内容,希望对大家学习javascript程序设计有所帮助。

Javascript 相关文章推荐
event.keyCode键码值表 附只能输入特定的字符串代码
May 15 Javascript
js操纵跨frame的三级联动select下拉选项实例介绍
May 19 Javascript
jquery实现简单的拖拽效果实例兼容所有主流浏览器
Jun 21 Javascript
JS 获取滚动条高度示例代码
Oct 24 Javascript
jQuery实现放大镜效果实例代码
Mar 17 Javascript
Vue.js每天必学之指令系统与自定义指令
Sep 07 Javascript
easyui-edatagrid.js实现回车键结束编辑功能的实例
Apr 12 Javascript
jQuery实现菜单栏导航效果
Aug 15 jQuery
js中数组对象去重的两种方法
Jan 18 Javascript
生产制造追溯系统之在线打印功能
Jun 03 Javascript
jquery将信息遍历到界面上实例代码
Jan 21 jQuery
JavaScrip如果基于url实现图片下载
Jul 03 Javascript
javascript实现不同颜色Tab标签切换效果
Apr 27 #Javascript
JS代码随机生成姓名、手机号、身份证号、银行卡号
Apr 27 #Javascript
JavaScript弹窗基础篇
Apr 27 #Javascript
jQuery绑定事件on()与弹窗的简要概述
Apr 27 #Javascript
jQuery.form插件的使用及跨域异步上传文件
Apr 27 #Javascript
js实现纯前端的图片预览
Apr 27 #Javascript
简介BootStrap model弹出框的使用
Apr 27 #Javascript
You might like
目录,文件操作详谈―PHP
2006/11/25 PHP
Yii1.1框架实现PHP极光推送消息通知功能
2018/09/06 PHP
PHP中的empty、isset、isnull的区别与使用实例
2019/03/22 PHP
onpropertypchange
2006/07/01 Javascript
一个cssQuery对象 javascript脚本实现代码
2009/07/21 Javascript
js 表格隔行颜色
2009/12/02 Javascript
最好用的省市二级联动 原生js实现你值得拥有
2013/09/22 Javascript
基于jquery和svg实现超炫酷的动画特效
2014/12/09 Javascript
JavaScript检测浏览器cookie是否已经启动的方法
2015/02/27 Javascript
JavaScript实现函数返回多个值的方法
2015/06/09 Javascript
深入理解JavaScript中的箭头函数
2015/07/28 Javascript
Javascript中关于Array.filter()的妙用详解
2016/12/04 Javascript
AngularJS中update两次出现$promise属性无法识别的解决方法
2017/01/05 Javascript
原生js实现form表单序列化的方法
2018/08/02 Javascript
vue单页面应用打开新窗口显示跳转页面的实例
2018/09/21 Javascript
微信小程序与公众号卡券/会员打通的问题
2019/07/25 Javascript
webpack.DefinePlugin与cross-env区别详解
2020/02/23 Javascript
react使用CSS实现react动画功能示例
2020/05/18 Javascript
[52:27]2018DOTA2亚洲邀请赛 3.31 小组赛B组 paiN vs Secret
2018/04/01 DOTA
[04:13]2018国际邀请赛典藏宝瓶Ⅱ饰品一览
2018/07/21 DOTA
Python使用multiprocessing实现一个最简单的分布式作业调度系统
2016/03/14 Python
用Python PIL实现几个简单的图片特效
2019/01/18 Python
详解10个可以快速用Python进行数据分析的小技巧
2019/06/24 Python
在Python中表示一个对象的方法
2019/06/25 Python
自定义django admin model表单提交的例子
2019/08/23 Python
在python Numpy中求向量和矩阵的范数实例
2019/08/26 Python
WatchShop法国:英国排名第一的独立手表零售商
2020/02/17 全球购物
档案室主任岗位职责
2014/02/12 职场文书
护士毕业实习感言
2014/03/05 职场文书
孝敬父母的演讲稿
2014/05/14 职场文书
领导党的群众路线教育实践活动个人对照检查材料
2014/09/23 职场文书
民主生活会剖析材料
2014/09/30 职场文书
超市采购员岗位职责
2015/04/07 职场文书
2016暑期校本培训心得体会
2016/01/08 职场文书
文明医院的标语集锦!
2019/07/24 职场文书
React如何使用axios请求数据并把数据渲染到组件
2022/08/05 Javascript