js数字转中文数字(js – 数字转中文)
导读:js - 数字转中文 JavaScript 中将阿拉伯数字转换为中文...
js - 数字转中文
JavaScript 中将阿拉伯数字转换为中文
转换代码
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: break case 2: break case 3: break 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 // console.log(new change("10086").pri_ary()) // 一万八十六chatgpt
JavaScript 中将阿拉伯数字转换为中文
function toChineseNum(num) { let chnNumChar = ["零", "一", "二", "三", "四", "五", "六", "七", "八", "九"]; let chnUnitSection = ["", "万", "亿", "万亿", "亿亿"]; let chnUnitChar = ["", "十", "百", "千"]; let strIns = , chnStr = ; let unitPos = 0; let zero = true; while (num > 0) { let v = num % 10; if (v === 0) { if (!zero) { zero = true; chnStr = chnNumChar[v] + chnStr; } } else { zero = false; strIns = chnNumChar[v]; strIns += chnUnitChar[unitPos]; chnStr = strIns + chnStr; } unitPos++; num = Math.floor(num / 10); } return chnStr; } toChineseNum(111180) // 一undefined一undefined一千一百八十创心域SEO版权声明:以上内容作者已申请原创保护,未经允许不得转载,侵权必究!授权事宜、对本内容有异议或投诉,敬请联系网站管理员,我们将尽快回复您,谢谢合作!