JavaScript实现把数字转换成中文


Posted in Javascript onJune 29, 2015
var _change = {
           ary0:["零", "一", "二", "三", "四", "五", "六", "七", "八", "九"],
           ary1:["", "十", "百", "千"],
           ary2:["", "万", "亿", "兆"],
           init:function (name) {
               this.name = name;
           },
           strrev:function () {
               var ary = []
               for (var i = this.name.length; i >= 0; i--) {
                   ary.push(this.name[i])
               }
               return ary.join("");
           }, //倒转字符串。
           pri_ary:function () {
               var $this = this
               var ary = this.strrev();
               var zero = ""
               var newary = ""
               var i4 = -1
               for (var i = 0; i < ary.length; i++) {
                   if (i % 4 == 0) { //首先判断万级单位,每隔四个字符就让万级单位数组索引号递增
                       i4++;
                       newary = this.ary2[i4] + newary; //将万级单位存入该字符的读法中去,它肯定是放在当前字符读法的末尾,所以首先将它叠加入$r中,
                       zero = ""; //在万级单位位置的“0”肯定是不用的读的,所以设置零的读法为空
 
                   }
                   //关于0的处理与判断。
                   if (ary[i] == '0') { //如果读出的字符是“0”,执行如下判断这个“0”是否读作“零”
                       switch (i % 4) {
                           case 0:
                               break;
                           //如果位置索引能被4整除,表示它所处位置是万级单位位置,这个位置的0的读法在前面就已经设置好了,所以这里直接跳过
                           case 1:
                           case 2:
                           case 3:
                               if (ary[i - 1] != '0') {
                                   zero = "零"
                               }
                               ; //如果不被4整除,那么都执行这段判断代码:如果它的下一位数字(针对当前字符串来说是上一个字符,因为之前执行了反转)也是0,那么跳过,否则读作“零”
                               break;
 
                       }
 
                       newary = zero + newary;
                       zero = '';
                   }
                   else { //如果不是“0”
                       newary = this.ary0[parseInt(ary[i])] + this.ary1[i % 4] + newary; //就将该当字符转换成数值型,并作为数组ary0的索引号,以得到与之对应的中文读法,其后再跟上它的的一级单位(空、十、百还是千)最后再加上前面已存入的读法内容。
                   }
 
               }
               if (newary.indexOf("零") == 0) {
                   newary = newary.substr(1)
               }//处理前面的0
               return newary;
           }
       }
 
       //创建class类
       function change() {
           this.init.apply(this, arguments);
       }
       change.prototype = _change
 
//创建实例
       var k = new change("00102040");
       alert(k.pri_ary())
Javascript 相关文章推荐
javascript之函数直接量(function(){})()
Jun 29 Javascript
JavaScript 精粹读书笔记(1,2)
Feb 07 Javascript
javascript操作css属性
Dec 30 Javascript
javascript 密码框防止用户粘贴和复制的实现代码
Feb 17 Javascript
常用的JavaScript模板引擎介绍
Feb 28 Javascript
JavaScript常用字符串与数组扩展函数小结
Apr 24 Javascript
JS实现快速的导航下拉菜单动画效果附源码下载
Nov 01 Javascript
详解在Angular项目中添加插件ng-bootstrap
Jul 04 Javascript
使用 vue-i18n 切换中英文效果
May 23 Javascript
最后说说Vue2 SSR 的 Cookies 问题
May 25 Javascript
详解Vue webapp项目通过HBulider打包原生APP(vue+webpack+HBulider)
Feb 02 Javascript
基于Web Audio API实现音频可视化效果
Jun 12 Javascript
使用Node.js配合Nginx实现高负载网络
Jun 28 #Javascript
jQuery模拟黑客帝国矩阵效果实例
Jun 28 #Javascript
jQuery往textarea中光标所在位置插入文本的方法
Jun 26 #Javascript
javascript实现相同事件名称,不同命名空间的调用方法
Jun 26 #Javascript
JavaScript实现数组随机排序的方法
Jun 26 #Javascript
JavaScript让Textarea支持tab按键的方法
Jun 26 #Javascript
javascript实现textarea中tab键的缩排处理方法
Jun 26 #Javascript
You might like
php获取用户IPv4或IPv6地址的代码
2012/11/15 PHP
php检测图片木马多进制编程实践
2013/04/11 PHP
PHP简单实现DES加密解密的方法
2016/07/12 PHP
laravel7学习之无限级分类的最新实现方法
2020/09/30 PHP
用 JSON 处理缓存
2007/04/27 Javascript
基于jquery的一个图片hover的插件
2010/04/24 Javascript
javascript开发中因空格引发的错误
2010/11/08 Javascript
潜说js对象和数组
2011/05/25 Javascript
js的onload事件及初始化按钮事件示例代码
2013/09/25 Javascript
jquery列表拖动排列(由项目提取相当好用)
2014/06/17 Javascript
jQuery实现带延时功能的水平多级菜单效果【附demo源码下载】
2016/09/21 Javascript
Node.js测试中的Mock文件系统详解
2016/11/21 Javascript
JS封装通过className获取元素的函数示例
2016/12/20 Javascript
Bootstrap输入框组件简单实现代码
2017/03/06 Javascript
js浏览器滚动条卷去的高度scrolltop(实例讲解)
2017/07/07 Javascript
vue动态绑定组件子父组件多表单验证功能的实现代码
2018/05/14 Javascript
解决Vue2.0 watch对象属性变化监听不到的问题
2018/09/11 Javascript
微信小程序当前时间时段选择器插件使用方法详解
2018/12/28 Javascript
详解在Vue.js编写更好的v-for循环的6种技巧
2020/04/14 Javascript
原生JS实现多条件筛选
2020/08/19 Javascript
Fiddler如何抓取手机APP数据包
2016/01/22 Python
在Python中输入一个以空格为间隔的数组方法
2018/11/13 Python
Python reshape的用法及多个二维数组合并为三维数组的实例
2020/02/07 Python
Python中常用的os操作汇总
2020/11/05 Python
python 用struct模块解决黏包问题
2020/11/07 Python
分享30个新鲜的CSS3打造的精美绚丽效果(附演示下载)
2012/12/28 HTML / CSS
日本最大化妆品和美容产品的综合口碑网站:cosme shopping
2019/08/28 全球购物
什么是封装
2013/03/26 面试题
市场营销求职信范文
2014/02/21 职场文书
法律七进实施方案
2014/03/15 职场文书
投标授权委托书范文
2014/08/02 职场文书
党员四风问题对照检查材料思想汇报
2014/09/16 职场文书
学生未请假就回家检讨书
2014/09/22 职场文书
医生个人自我剖析材料
2014/10/08 职场文书
学前教育见习总结
2015/06/23 职场文书
Java 多线程协作作业之信号同步
2022/05/11 Java/Android