在js中,用户点击添加怎么才能让文本每次加一呢?(中文的一,每次加一个)
我的页面如下
我想点击新增检查项的时候,新增出来任务二
在点击新增出来任务三
数字的我会,但是中文的我就不会了,
我用的框架是Vue.js,请大神赐教
在js中,用户点击添加怎么才能让文本每次加一呢?(中文的一,每次加一个)
我的页面如下
我想点击新增检查项的时候,新增出来任务二
在点击新增出来任务三
数字的我会,但是中文的我就不会了,
我用的框架是Vue.js,请大神赐教
我的思路是将数字1和汉字一做成一一对应,然后用户加1的时候看数值,之后将数值拆分,因为数值可能是十位百位或者千位,所以还得建一个['十','百','千']的数组,然后对数值取膜,这个有点烦···我封装了一个函数但是还是有点缺陷
function smalltoBIG(n) {
var fraction = ['角', '分'];
var digit = ['零', '壹', '贰', '叁', '肆', '伍', '陆', '柒', '捌', '玖'];
var unit = [['元', '万', '亿'], ['', '拾', '佰', '仟']];
var head = n < 0 ? '欠' : '';
n = Math.abs(n);
var s = '';
for (var i = 0; i < fraction.length; i++) {
s += (digit[Math.floor(n * 10 * Math.pow(10, i)) % 10] + fraction[i]).replace(/零./, '');
}
s = s || '整';
n = Math.floor(n);
for (var j = 0; j < unit[0].length && n > 0; j++) {
var p = '';
for (var k = 0; k < unit[1].length && n > 0; k++) {
p = digit[n % 10] + unit[1][k] + p;
n = Math.floor(n / 10);
}
s = p.replace(/(零.)*零$/, '').replace(/^$/, '零') + unit[0][j] + s;
}
return head + s.replace(/(零.)*零元/, '元').replace(/(零.)+/g, '零').replace(/^整$/, '零元整');
}
console.log(smalltoBIG(1234.4));
13 回答12.7k 阅读
7 回答1.9k 阅读
3 回答1.1k 阅读✓ 已解决
2 回答1.1k 阅读✓ 已解决
6 回答812 阅读✓ 已解决
2 回答1.4k 阅读✓ 已解决
6 回答1k 阅读
index
表示任务序号,数据类型为Number
控制台打印结果即为中文,参考了楼上使用了
Number.toLocaleString()
的方法转换成中文,我这个过滤器只过滤到千位,并且没有过滤小数点,请题主参考逻辑后自行修改