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 相关文章推荐
JavaScript 错误处理与调试经验总结
Aug 10 Javascript
javascript jscroll模拟html元素滚动条
Dec 18 Javascript
JQuery获取样式中的background-color颜色值的问题
Aug 20 Javascript
解析JavaScript中instanceof对于不同的构造器或许都返回true
Dec 03 Javascript
分享2个jQuery插件--jquery.fileupload与artdialog
Dec 26 Javascript
JS继承用法实例分析
Feb 05 Javascript
JavaScript ParseFloat()方法
Dec 18 Javascript
JS冒泡事件与事件捕获实例详解
Nov 25 Javascript
微信小程序动态的加载数据实例代码
Apr 14 Javascript
基于cropper.js封装vue实现在线图片裁剪组件功能
Mar 01 Javascript
巧妙运用v-model实现父子组件传值的方法示例
Apr 07 Javascript
vue中div禁止点击事件的实现
Apr 02 Vue.js
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将向Java靠拢
2006/10/09 PHP
PHP+Javascript实现在线拍照功能实例
2015/07/18 PHP
PHP生成树的方法
2015/07/28 PHP
修改WordPress中文章编辑器的样式的方法详解
2015/12/15 PHP
thinkPHP数据库增删改查操作方法实例详解
2016/12/06 PHP
Zend Framework入门教程之Zend_Registry组件用法详解
2016/12/09 PHP
身份证号码前六位所代表的省,市,区, 以及地区编码下载
2007/04/12 Javascript
Firebug入门指南(Firefox浏览器)
2010/08/21 Javascript
在JavaScript中实现类的方式探讨
2013/08/28 Javascript
JavaScript中number转换成string介绍
2014/12/31 Javascript
javascript正则表达式总结
2016/02/29 Javascript
Vuejs第十一篇组件之slot内容分发实例详解
2016/09/09 Javascript
JS 滚动事件window.onscroll与position:fixed写兼容IE6的回到顶部组件
2016/10/10 Javascript
NodeJS处理Express中异步错误
2017/03/26 NodeJs
ES6 javascript中class静态方法、属性与实例属性用法示例
2017/10/30 Javascript
bootstrap里bootstrap动态加载下拉框的实例讲解
2018/08/10 Javascript
python实现哈希表
2014/02/07 Python
Python实现简单的文件传输与MySQL备份的脚本分享
2016/01/03 Python
python中的错误处理
2016/04/10 Python
Python中利用aiohttp制作异步爬虫及简单应用
2018/11/29 Python
python scp 批量同步文件的实现方法
2019/01/03 Python
python DataFrame 取差集实例
2019/01/30 Python
Python实现ATM系统
2020/02/17 Python
关于win10在tensorflow的安装及在pycharm中运行步骤详解
2020/03/16 Python
Python3 pickle对象串行化代码实例解析
2020/03/23 Python
Django基于Models定制Admin后台实现过程解析
2020/11/11 Python
CSS3实现酷炫的3D旋转透视效果
2019/11/21 HTML / CSS
欧舒丹英国官网:购买欧舒丹护手霜等明星产品
2017/01/17 全球购物
Sixt美国租车:高端豪华车型自驾体验
2017/09/02 全球购物
J2EE系统只能是基于web
2015/09/08 面试题
致100米运动员广播稿
2014/02/14 职场文书
大客户经理岗位职责
2015/04/09 职场文书
如何写通讯稿
2015/07/22 职场文书
员工聘用合同范本
2015/09/21 职场文书
高三数学教学反思
2016/02/18 职场文书
酒店工程部的岗位职责汇总大全
2019/10/23 职场文书