Element input输入框,只允许数值(数字)输入

在实际开发中,涉及到金额并且存在很严格的校验规则的情况下,为了更好的用户体验,从而写了下面的,代码

首先下面是,element组件的具体代码

<div class="class-box-input">
      <el-input placeholder="请输入内容" @input="handleInput" style="width: 300px;" maxlength="7" v-model="input" clearable></el-input>
</div>

js代码:实际就是使用了js中的正则匹配,然后替换

 handleInput(v) {


            let cleanedValue = v.replace(/[^\d.]/g, '');//移除非数字和小数点

            cleanedValue  = cleanedValue.replace(/^0\d+/g, '');//当输入第二个00的时候直接清空输入框

            if (/\.\d+\./.test(cleanedValue)) {//当输入多个小数点匹配其数字和小数点组合
            cleanedValue = cleanedValue.replace(/\.\d+\./g, '.'); // 移除中间的数字和小数点组合
            }

            let parts = cleanedValue.split('.');//分割小数点

            if (parts.length === 2) {
                this.input = `${parts[0].replace(/^0+(\d)/, '$1')}.${parts[1].slice(0, 2)}`;
            } else {
            const firstDigit = cleanedValue.match(/\d/);

            if (firstDigit && firstDigit[0] !== '0') {
                this.input = cleanedValue.endsWith('.') ? cleanedValue : cleanedValue;
            } else {
                this.input = firstDigit ? cleanedValue.replace(/^0+(\d)/, '$1') : cleanedValue.slice(1);
            }
            }

                console.log(this.input, '+++++++++++');
            },

为了更好的用户体验,采取了直接限制用户输入的价格,直接清空输入框,此输入框可输入,小数、整数,不可输入英文,与不合法的数字

下面是效果图:

  • 2
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值