zoukankan      html  css  js  c++  java
  • 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:'' }); }}
  • 相关阅读:
    每日总结50
    每日总结49
    每日总结48
    每日总结47
    每日总结46
    每日总结45
    每日总结44
    每日总结42
    每日总结41
    每日总结39
  • 原文地址:https://www.cnblogs.com/lixz/p/11205102.html
Copyright © 2011-2022 走看看