正在阅读:
- 首页 » 开发运维 » 前端 » vue js将数字金额转换成人民币大写
vue js将数字金额转换成人民币大写
vue js将数字金额转换成人民币大写
建立一个函数,如
digitUppercase(price) {
const fraction = ['角', '分']
const digit = ['零', '壹', '贰', '叁', '肆', '伍', '陆', '柒', '捌', '玖']
const unit = [
['元', '万', '亿'],
['', '拾', '佰', '仟'],
]
let num = Math.abs(price)
let s = ''
fraction.forEach((item, index) => {
s += (digit[Math.floor(num * 10 * 10 ** index) % 10] + item).replace(/零./, '')
})
s = s || '整'
num = Math.floor(num)
for (let i = 0; i < unit[0].length && num > 0; i += 1) {
let p = ''
for (let j = 0; j < unit[1].length && num > 0; j += 1) {
p = digit[num % 10] + unit[1][j] + p
num = Math.floor(num / 10)
}
s = p.replace(/(零.)*零$/, '').replace(/^$/, '零') + unit[0][i] + s
}
return s
.replace(/(零.)*零元/, '元')
.replace(/(零.)+/g, '零')
.replace(/^整$/, '零元整')
},注意:如果存在分单位精度偏差,如2347.64 可能会转换成 2347.63 【贰仟叁佰肆拾柒元陆角叁分】
将
s += (digit[Math.floor(num * 10 * 10 ** index) % 10] + item).replace(/零./, '')
修改为
s += (digit[Math.floor((num * 10 * 10 ** index).toFixed(2)) % 10] + item).replace(/零./, '')
计算效果:

对比:
该日志由 bemender 于 2022年09月27日 发表
转载请注明文本地址:http://www.bemhome.com/post/161.html