input输入框只能输入数字且保留两位小数场景演练(金额)

49 篇文章 1 订阅
34 篇文章 2 订阅

以下方法看自己用的ui需求的需求增加不同的方法

1、给文本框增加一个onChange方法,

//   针对输入的金额做特殊处理
const onCustomMoneyValidate = (e) => {
    e.target.value = e.target.value.replace(/[^\d.]/g, ''); // 只能输入"数字"和"."
    e.target.value = e.target.value.replace(/^\./g, ''); // 第一位字符不能为"."
    e.target.value = e.target.value.replace(/\.{2,}/g, '.'); // 只保留第一个. 清除多余的
    e.target.value = e.target.value.replace('.', '$#$').replace(/\./g, '').replace('$#$', '.'); // 只能输入一个小数点且只保留一个
    e.target.value = e.target.value.replace(/^(\-)*(\d+)\.(\d\d).*$/, '$1$2.$3'); // 只能输入两位小数
    if (e.target.value.indexOf('.') < 0 && e.target.value !== '')
      e.target.value = parseFloat(e.target.value); // 以上已经过滤,此处控制的是如果没有小数点,首位不能为类似于 01、02的金额
    // TODOS 做赋值操作
};

2、对金额最后是小数点的情况做特殊处理

//  失焦规整金额(防止最后一位是小数点的情况)  payMoney是绑定的input的值
const onCustomBlurRegular = () => {
    if (payMoney && payMoney.substr(payMoney.length - 1, 1) === '.') {
      let newVal = payMoney.substr(0, payMoney.length - 1);
      // TODOS 做重新赋值操作
    }
};

3、金额最后如果是小数点做拓展(看需求)

for(let i = 0; i < payMoeny.length; i++) {
  if(payMoeny.charAt(0) == '0' && payMoeny.charAt(1) != '.') {
    payMoeny = payMoeny.substring(1);  // 把第一个字符去掉,返回剩余部分
  } else {
  }
  if(payMoeny.charAt(payMoeny.length - 1) == '.') payMoeny = payMoeny + '00' // 后面加上00
}

交流

1、QQ群:可添加qq群共同进阶学习: 进军全栈工程师疑难解  群号:   856402057

2、公众号:公众号「进军全栈攻城狮」 ,对前端技术保持学习爱好者。我会经常分享自己所学所看的干货,在进阶的路上,共勉!通过公众号可加我vx拉群     

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值