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

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

以下方法看自己用的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
}

交流

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

相关文章
|
5月前
|
JavaScript
vue组件封装 | 数字输入框(限制只能输入数字的input,可以指定小数点位数,最大值、最小值)
vue组件封装 | 数字输入框(限制只能输入数字的input,可以指定小数点位数,最大值、最小值)
310 7
用输入框输入一个成绩,来判断 成绩的等级 90-100分为优秀,70-89为良好,60-69为及格,60分以下为还需要继续努力,当输入为非数字的时候显示非法字符。
用输入框输入一个成绩,来判断 成绩的等级 90-100分为优秀,70-89为良好,60-69为及格,60分以下为还需要继续努力,当输入为非数字的时候显示非法字符。
439 0
正则表达式显示input框只能输入数字或者保持小数点后两位
正则表达式显示input框只能输入数字或者保持小数点后两位
355 0
input输入框输入只能输入数字、字母等组合的正则表达式
input输入框输入只能输入数字、字母等组合的正则表达式
718 0
输入1-5为工作日,输出6-7为休息日
输入1-5为工作日,输出6-7为休息日
191 0
输入1-5为工作日,输出6-7为休息日
用户输入学号,如果是以aabcddef开头,并且后边是4位数字,前两位大于06小于等于当前年份。判断用户输入是否合法
用户输入学号,如果是以aabcddef开头,并且后边是4位数字,前两位大于06小于等于当前年份。判断用户输入是否合法
115 0
input限制只能输入小数或者数字
input限制只能输入小数或者数字
150 0
用正则表达式限制input输入框只能输入整数的一段简单代码
要实现input框只能输入正整数,如果检测到输入其他类型的数据就直接为0;代码如下:
425 0