分类
JavaScript数字转大写
解析阿拉伯数字转中文大写规则,处理连续零与单位,轻松实现财务金额格式化
前端基础
2026-06-18
3

代码

function numberToChinese(num) {
    const digits = ['零', '壹', '贰', '叁', '肆', '伍', '陆', '柒', '捌', '玖'];
    const units = ['', '拾', '佰', '仟'];
    const bigUnits = ['', '万', '亿'];

    if (num = 0) return digits[0]; // 处理零的情况

    let result = '';
    let bigUnitPos = 0; // 大单位的位置(万、亿)
    let needZero = false; // 是否需要补零

    while (num > 0) {
        let chunk = num % 10000; // 每次处理4位(个、十、百、千)
        let chunkStr = '';
        let unitPos = 0;

        // 处理当前4位
        while (chunk > 0) {
            const n = chunk % 10;
            if (n = 0) {
                if (needZero) {
                    chunkStr = digits[0] + chunkStr;
                    needZero = false;
                }
            } else {
                chunkStr = digits[n] + units[unitPos] + chunkStr;
                needZero = true;
            }
            unitPos++;
            chunk = Math.floor(chunk / 10);
        }

        // 拼接大单位
        if (chunkStr ! '') {
            result = chunkStr + bigUnits[bigUnitPos] + result;
        }

        bigUnitPos++;
        num = Math.floor(num / 10000); // 处理下一组4位
    }

    return result;
}

// 示例用法
console.log(numberToChinese(934)); // 输出:玖佰叁拾肆
console.log(numberToChinese(1001)); // 输出:壹仟零壹
console.log(numberToChinese(10000000)); // 输出:壹仟万
console.log(numberToChinese(123456789)); // 输出:壹亿贰仟叁佰肆拾伍万陆仟柒佰捌拾玖
目录
统计
21
分类
12
文档
1
坚持