input框输入金额处理的解决办法

最近已经上线的项目突然出现了input输入金额删除时出现问题,网上各种搜索都没有搜到想要的,今天就以react框架为例子进行代码奉献,我会把需求及解决方法写出来,希望对朋友们有用。

如有更好地实现方式欢迎指点!

一、需求

1、只允许输入数字

2、只允许输入一个小数点,且小数点只能有一个,后面最多可输两位小数

3、金额转成大写

4、控制金额输入的位数

二、实现方法

 constructor中代码:

constructor(props) {
       super();

        this.state = {
               saveMoney:' ' ,input框里的初始值
               bigText:' ',大写金额
        };
         this.handleChangeSave= this.handleChangeSave.bind(this);
}


render中代码:

<input type="text" id='box' 
    value={this.state.saveMoney}
    onChange={this.handleChangeSave} 
  />
<p className={styles.daxie}>{this.state.bigText}</p>


handleChangeSave方法: 
handleChangeSave(e) {
大写金额转换方法:
            function DX(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 i = 0; i < unit[0].length && n > 0; i++) {
                var p = '';
                for (var j = 0; j < unit[1].length && n > 0; j++) {
                p = digit[n % 10] + unit[1][j] + p;
                n = Math.floor(n / 10);
                  }
                s = p.replace(/(零.)*零$/, '').replace(/^$/, '零') + unit[0][i] + s;
                }
              return head + s.replace(/(零.)*零元/, '元').replace(/(零.)+/g, '零').replace(/^整$/, '零元整');
             }
            const bigText= DX(num); 调用大写方法


获取值并进行实时改变input框的数据显示,进行位数控制
const data = e.target.value; 获取输入的值
const num = data.replace(/,/g, '');
把输入的逗号变成空
var reg = /^[0-9\.\d]+$/; 正则匹配输入的是否符合规范 
if (reg.test(num))
{ if (num.indexOf('.') > '-1') 判断小数点存在的情况下
{ const decimal = num.split('.')[1];
const wholeNumber =num.split('.')[0];
if(wholeNumber == ''){
this.setState({ saveMoney: '0'+'.'+decimal, 如果小数点前为空的话默认为0
bigText:bigText });}
else{
if (num >= 1000 && decimal.length
< 3&& num.length < 15)
{ this.setState({ saveMoney: parseInt(num)+'.'+decimal, bigText:bigText }); }
else if (num
>= 0 && num < 1000 && decimal.length < 3)
{ this.setState({
saveMoney: parseInt(num)+'.'+decimal,
bigText:bigText }); } } }
else { if(num
>= 0 && num.length < 12){ 判断小数点不存在的情况下
this.setState({
saveMoney: num,
bigText:bigText }); } } }
else if (num
== '') 判断为空时
{ this.setState({
saveMoney: '',
bigText:'' }); }}

 

posted @ 2019-07-18 09:31  蓝色~~之恋  阅读(3023)  评论(0编辑  收藏  举报