elementui中的el-input-number只能输入数字

4 篇文章 0 订阅
1 篇文章 0 订阅
该博客主要讨论了在火狐浏览器中,如何确保`el-input-number`组件只能接受数字输入的问题。作者尝试了使用`onKeypress`事件过滤非数字字符的方法,但发现仍能在输入框中输入非数字文字。为解决此问题,作者添加了`@input.native`事件,并在事件处理函数中通过正则表达式替换掉非数字字符,同时限制输入值不超过99。通过这种方法,成功地阻止了在火狐中输入非数字内容。
摘要由CSDN通过智能技术生成

需求是只能输入数字,输入框中不能有除数字外的文字

查询资料发现都说加这段代码

onKeypress="return (/[\d]/.test(String.fromCharCode(event.keyCode)))"

 但是在火狐中输入框中仍然能输入除数字外的文字,

给el-input-number加input事件,因为是组件所以是@input.native:

<el-input-number
  v-model="num"
  onKeypress="return (/[\d]/.test(String.fromCharCode(event.keyCode)))" 
  @blur="inputBlur"
  @input.native="onInput"
  :min="1"
  :max="99"
  label="描述文字"
></el-input-number>
  onInput(e) {
       console.log(e.target.value,"yjm")
       e.target.value=e.target.value.replace(/[^\d.]/g,'');
        if(parseInt(e.target.value)>99){
         e.target.value=99
       }
    },

问题解决

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值