js数字转换成汉字

大家在工作中经常遇到需要将数据转换成汉字的情况,比如 1234转为 一千二百三十四的形式

代码如下:

1、定义变量

var chnNumChar =  ["零", "一", "二", "三", "四", "五", "六", "七", "八", "九"];
var chnUnitSection = ["", "万", "亿", "万亿", "亿亿"];
var chnUnitChar = ["", "十", "百", "千"];

2、获取中文

/**
 * 获取中文
 * @param num
 * @returns {*}
 */
SectionToChinese: function (section) {
 var ori = section;
 var strIns = '';
 var chnStr = '';
 var unitPos = 0;
 var zero = true;
 while (section > 0) {
 var v = section % 10;
 if (v === 0) {
 if (!zero) {
 zero = true;
 chnStr = this.chnNumChar[v] + chnStr;
 }
 } else {
 zero = false;
 strIns = this.chnNumChar[v];
 strIns += this.chnUnitChar[unitPos];
 chnStr = strIns + chnStr;
 }
 unitPos++;
 section = Math.floor(section / 10);
 }
 if (ori < 20) {
 chnStr = chnStr.replace('一十', '十');
 }
 return chnStr;
}

3、 数字转中文

/**
 * 数字转中文
 * @param num
 * @returns {*}
 */
numberToChanie: function (num) {
 var unitPos = 0;
 var strIns = '', chnStr = '';
 var needZero = false;

 if (num === 0) {
 return JsUlits.chnNumChar[0];
 }

 while (num > 0) {
 var section = num % 10000;
 if (needZero) {
 chnStr = this.chnNumChar[0] + chnStr;
 }
 strIns = this.SectionToChinese(section);
 strIns += (section !== 0) ? this.chnUnitSection[unitPos] : this.chnUnitSection[0];
 chnStr = strIns + chnStr;
 needZero = (section < 1000) && (section > 0);
 num = Math.floor(num / 10000);
 unitPos++;
 }
 return chnStr;
}
  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
### 回答1: 答: function numberToChinese(num) { var chnNumChar = ["零","一","二","三","四","五","六","七","八","九"]; var chnUnitSection = ["","万","亿","万亿","亿亿"]; var chnUnitChar = ["","十","百","千"]; var strIns = '', chnStr = ''; var unitPos = 0; var zero = true; while(num > 0){ var 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; } ### 回答2: 以下是一个将数字换为中文的JavaScript代码: ```javascript // 定义中文数字 var chineseNumbers = { '0': '零', '1': '一', '2': '二', '3': '三', '4': '四', '5': '五', '6': '六', '7': '七', '8': '八', '9': '九' }; function numberToChinese(number) { var chineseString = ''; if (number === 0) { return chineseNumbers['0']; } while (number > 0) { var digit = number % 10; chineseString = chineseNumbers[digit] + chineseString; number = Math.floor(number / 10); } return chineseString; } // 测试代码 console.log(numberToChinese(123)); // 输出: 一百二十三 console.log(numberToChinese(456789)); // 输出: 四十五万六千七百八十九 ``` 这个代码定义了一个对象`chineseNumbers`,其中包含了0-9的中文数字的映射。然后定义了一个函数`numberToChinese`用来将数字换为中文字符串。 在函数内部,我们首先判断输入的数字是否为0,如果是0则直接返回'零'。 接下来使用一个while循环,每次循环的目的是将数字的每一位转换成对应的中文数字并拼接到结果字符串`chineseString`的前面。通过对10取余获得当前位的数字,然后找到对应的中文数字并拼接。最后将输入的数字除以10取整,继续下一次循环直到数字变为0为止。 最后返回换后的中文字符串。 以上代码只是简单的将数字转换成中文字符串,如果需要更复杂的语法规则,例如千、万、亿等单位的换,还需要进一步完善代码。 ### 回答3: 以下是一个实现将数字转换成中文的 JavaScript 代码: ```javascript function numberToChinese(num) { const chineseNums = ["零", "一", "二", "三", "四", "五", "六", "七", "八", "九"]; const chineseUnits = ["", "十", "百", "千", "万", "亿"]; if (num === 0) { return chineseNums[0]; } let result = ""; let unitIndex = 0; let temp = num; while (temp > 0) { const digit = temp % 10; if (digit !== 0) { result = chineseNums[digit] + chineseUnits[unitIndex] + result; } else if (unitIndex === 0 || result.charAt(0) !== chineseNums[0]) { result = chineseNums[digit] + result; } temp = Math.floor(temp / 10); unitIndex++; } return result; } // 示例用法 console.log(numberToChinese(12345)); // 输出:一万二千三百四十五 console.log(numberToChinese(6)); // 输出:六 console.log(numberToChinese(2000000000)); // 输出:二十亿 console.log(numberToChinese(1100100)); // 输出:一百一十万零一百 ``` 该代码定义了一个 `numberToChinese` 函数,该函数接受一个数字作为参数,并返回一个表示该数字对应中文的字符串。 实现思路是将数字拆分为个位、十位、百位等,并使用 `chineseNums` 数组将对应的中文数字换过来。同时使用 `chineseUnits` 数组来表示单位(十、百、千、万、亿)。通过对数字进行取余和整除的操作,循环处理每个数字位上的值,并将换后的中文数字和对应的单位拼接到最终的结果字符串上。 需要注意的是,当数字末尾为零时,根据中文数字的表示规则,只有在非个位数的位置上才添加 "零"。此外,处理完每位数字后,需要对 `unitIndex` 和 `temp` 进行递增和递除的操作,以便处理下一位数字。 示例用法展示了几个测试案例,代码能够正确将数字转换成对应的中文字符串。
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值