正在阅读:
- 首页 » 开发运维 » 前端 » 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日 发表
转载请注明文本地址:https://www.bemhome.com/post/161.html