输入金额转化成对应的大写
<el-input
v-model="text"
placeholder="Please input"
type="text"
@blur="changeMoney()"
/>
<div>
大写:{{money}}
</div>
逻辑代码:
const changeChinese = (n)=>{
if(n == 0 || n == '0'){
return '零元'
}
if(n === '' || typeof n === 'undefined'){
return ''
}
if(!/^(0|[1-9]\d*)(\.\d+)?$/.test(n)){
return '数据非法'
}
n = parseFloat((n + '').replace(/[^\d\\.-]/g, '')) + ''
var unit = '仟佰拾亿仟佰拾万仟佰拾圆角分'
var str = ''
n+='00'
var p = n.indexOf('.')
if(p >= 0){
n = n.substring(0,p) + n.substr(p + 1,2)
}
unit = unit.substr(unit.length - n.length)
for(var i = 0;i<n.length;i++){
str += '零壹贰叁肆伍陆柒捌玖' .charAt(n.charAt(i)) + unit.charAt(i)
}
return str
.replace(/零(仟|佰|拾|角)/g, '零')
.replace(/(零)+/g, '零')
.replace(/零(万|亿|圆)/g,'$1')
.replace(/(亿)万|壹(拾)/g,'$1$2')
.replace(/^圆零?|零分/g, '')
.replace(/圆$/g,'圆整')
}
const money = ref('')
const changeMoney = ()=>{
money.value = changeChinese(text.value)
}