131 lines
3.2 KiB
Vue
131 lines
3.2 KiB
Vue
|
|
<template>
|
||
|
|
<view>
|
||
|
|
<uni-easyinput :inputBorder="false" class="w-form-input" type="digit" v-model="_value" v-if="!readonly"
|
||
|
|
:placeholder="formProps.placeholder || '请输入金额'" />
|
||
|
|
<text class="w-form-input-rv" v-else>{{_value}}</text>
|
||
|
|
<view v-if="formProps.showChinese" style="font-size: 24rpx; color: #a2a2a2;">
|
||
|
|
{{moneyValue !== '' ? `大写:${moneyValue}` : ''}}
|
||
|
|
</view>
|
||
|
|
</view>
|
||
|
|
|
||
|
|
</template>
|
||
|
|
|
||
|
|
<script setup>
|
||
|
|
import { computed } from 'vue'
|
||
|
|
import { parseNumber } from '@/utils/tool.js'
|
||
|
|
|
||
|
|
const props = defineProps({
|
||
|
|
formProps: {
|
||
|
|
type: Object,
|
||
|
|
default: () => {
|
||
|
|
return {}
|
||
|
|
}
|
||
|
|
},
|
||
|
|
modelValue: Number | String,
|
||
|
|
readonly: Boolean
|
||
|
|
})
|
||
|
|
|
||
|
|
const _value = computed({
|
||
|
|
get() {
|
||
|
|
return parseNumber(props.modelValue, props.formProps.precision)
|
||
|
|
},
|
||
|
|
set(val) {
|
||
|
|
emits('update:modelValue', parseNumber(val, props.formProps.precision))
|
||
|
|
}
|
||
|
|
})
|
||
|
|
|
||
|
|
const emits = defineEmits(['update:modelValue'])
|
||
|
|
|
||
|
|
const moneyValue = computed(() => convertCurrency(props.modelValue))
|
||
|
|
|
||
|
|
function convertCurrency(money) {
|
||
|
|
//汉字的数字
|
||
|
|
const cnNums = ['零', '壹', '贰', '叁', '肆', '伍', '陆', '柒', '捌', '玖'];
|
||
|
|
//基本单位
|
||
|
|
const cnIntRadice = ['', '拾', '佰', '仟'];
|
||
|
|
//对应整数部分扩展单位
|
||
|
|
const cnIntUnits = ['', '万', '亿', '兆'];
|
||
|
|
//对应小数部分单位
|
||
|
|
const cnDecUnits = ['角', '分', '毫', '厘'];
|
||
|
|
//整数金额时后面跟的字符
|
||
|
|
const cnInteger = '整';
|
||
|
|
//整型完以后的单位
|
||
|
|
const cnIntLast = '元';
|
||
|
|
//最大处理的数字
|
||
|
|
let maxNum = 999999999999999.9999;
|
||
|
|
//金额整数部分
|
||
|
|
let integerNum;
|
||
|
|
//金额小数部分
|
||
|
|
let decimalNum;
|
||
|
|
//输出的中文金额字符串
|
||
|
|
let chineseStr = '';
|
||
|
|
//分离金额后用的数组,预定义
|
||
|
|
let parts;
|
||
|
|
if (money === '') {
|
||
|
|
return '';
|
||
|
|
}
|
||
|
|
money = parseFloat(money);
|
||
|
|
if (money >= maxNum) {
|
||
|
|
//超出最大处理数字
|
||
|
|
return '';
|
||
|
|
}
|
||
|
|
if (money === 0) {
|
||
|
|
chineseStr = cnNums[0] + cnIntLast + cnInteger;
|
||
|
|
return chineseStr;
|
||
|
|
}
|
||
|
|
//转换为字符串
|
||
|
|
money = money.toString();
|
||
|
|
if (money.indexOf('.') === -1) {
|
||
|
|
integerNum = money;
|
||
|
|
decimalNum = '';
|
||
|
|
} else {
|
||
|
|
parts = money.split('.');
|
||
|
|
integerNum = parts[0];
|
||
|
|
decimalNum = parts[1].substr(0, 4);
|
||
|
|
}
|
||
|
|
//获取整型部分转换
|
||
|
|
if (parseInt(integerNum, 10) > 0) {
|
||
|
|
var zeroCount = 0;
|
||
|
|
var IntLen = integerNum.length;
|
||
|
|
for (let i = 0; i < IntLen; i++) {
|
||
|
|
let n = integerNum.substr(i, 1);
|
||
|
|
let p = IntLen - i - 1;
|
||
|
|
let q = p / 4;
|
||
|
|
let m = p % 4;
|
||
|
|
if (n == '0') {
|
||
|
|
zeroCount++;
|
||
|
|
} else {
|
||
|
|
if (zeroCount > 0) {
|
||
|
|
chineseStr += cnNums[0];
|
||
|
|
}
|
||
|
|
//归零
|
||
|
|
zeroCount = 0;
|
||
|
|
chineseStr += cnNums[parseInt(n)] + cnIntRadice[m];
|
||
|
|
}
|
||
|
|
if (m == 0 && zeroCount < 4) {
|
||
|
|
chineseStr += cnIntUnits[q];
|
||
|
|
}
|
||
|
|
}
|
||
|
|
chineseStr += cnIntLast;
|
||
|
|
}
|
||
|
|
//小数部分
|
||
|
|
if (decimalNum !== '') {
|
||
|
|
let decLen = decimalNum.length;
|
||
|
|
for (let i = 0; i < decLen; i++) {
|
||
|
|
let n = decimalNum.substr(i, 1);
|
||
|
|
if (n !== '0') {
|
||
|
|
chineseStr += cnNums[Number(n)] + cnDecUnits[i];
|
||
|
|
}
|
||
|
|
}
|
||
|
|
}
|
||
|
|
if (chineseStr === '') {
|
||
|
|
chineseStr += cnNums[0] + cnIntLast + cnInteger;
|
||
|
|
} else if (decimalNum === '') {
|
||
|
|
chineseStr += cnInteger;
|
||
|
|
}
|
||
|
|
return chineseStr;
|
||
|
|
}
|
||
|
|
</script>
|
||
|
|
|
||
|
|
<style>
|
||
|
|
</style>
|