说在前面
最近在做一个需求,需要在用户输入数字失焦后实时将数字转为大写中文,聚焦的时候将大写中文转为数字以便用户继续修改。这里我们可以封装一个通用指令来做转换,接下来就让我们一起来实现一个转换指令吧。
效果展示
体验地址
实现思路
1、数字转大写中文
首先我们需要先实现一个函数,将数字转为大写中文的形式。
(1)函数入参
const numberToChineseWords = (num, unit = "元", append = "整") => {
...};
- num
必出参数,默认值为 “元”,需要进行转换的数字。
- unit
可选参数,默认值为 “元”,用于指定整数金额部分后面跟随的单位字符。通过设置这个参数,可以根据不同的业务场景或语言习惯需求来改变金额单位的显示,比如在某些特定财务报表中可能需要显示为 “圆” 等情况,就可以传入相应的字符作为该参数的值进行自定义。
- append
可选参数,默认值为 “整”,用于在金额为整数时,在转换后的中文金额表述后面追加的字符。比如常见的整数金额书写规范中会添加 “整” 字表示没有小数部分,若不需要这个追加字符或者有其他业务特定的追加内容要求,可以通过修改该参数来实现。
(2)辅助常量
用于辅助完成数字到中文的转换。
// 汉字的数字
const cnNums = ["零", "壹", "贰", "叁", "肆", "伍", "陆", "柒", "捌", "玖"];
// 基本单位
const cnIntRadice = ["", "拾", "佰", "仟"];
// 对应整数部分扩展单位
const cnIntUnits = ["", "万", "亿", "兆"];
// 对应小数部分单位
const cnDecUnits = ["角", "分", "毫", "厘"];
// 最大处理的数字
const maxNum =