当前位置:   article > 正文

el-input限制只能输入数字,且保留2位小数_el-input只能输入数字和最多两位小数

el-input只能输入数字和最多两位小数

        项目需求el-input组件输入的时候使用v-model.number="value"一开始可以输入任何字符。除非第一次输入为数字,后面输入的内容才会被限制,只能输入数字。这个并不符合需求。

我们要实现如下功能:

      1.必须为数字

      2.只能有一个小数点

      3.小数点后保留两位小数

      4.当第一位输入小数点的时候自动补全,补为 0.

      5.除非是小数,否则数字不能以0开头

一、绑定input事件对输入的内容进行自定义过滤

  1. <el-input placeholder="售价" @input="limitInput($event, 'sellingPrice')" v-model.trim="form.sellingPrice">
  2. </el-input>
  1. /**
  2. * @param {string} value - 输入的值
  3. * @param {string} name - 匹配的对象属性
  4. */
  5. limitInput(value, name) {
  6. let dat =
  7. ("" + value) // 第一步:转成字符串
  8. .replace(/[^\d^\.]+/g, "") // 第二步:把不是数字,不是小数点的过滤掉
  9. .replace(/^0+(\d)/, "$1") // 第三步:第一位0开头,0后面为数字,则过滤掉,取后面的数字
  10. .replace(/^\./, "0.") // 第四步:如果输入的第一位为小数点,则替换成 0. 实现自动补全
  11. .match(/^\d*(\.?\d{0,2})/g)[0] || ""; // 第五步:最终匹配得到结果 以数字开头,只有一个小数点,而且小数点后面只能有0到2位小数
  12. // 限制输入最大值为100
  13. if (Number(dat) >= 100) {
  14. return;
  15. }
  16. this.form[name] = dat;
  17. },

二、利用 Onkeyup 事件

  1. <el-input
  2. Onkeyup="this.value=this.value.replace(/[^\d^\.]+/g,'').replace(/^0+(\d)/,'$1').replace(/^\./,'0.').match(/\d+.?\d{0,2}/);this.dispatchEvent(new Event('input'))"
  3. v-model.trim="form.test"
  4. ></el-input>

参考链接:https://www.jianshu.com/p/75df2814be0e

其他正则记录

1、金额的正则表达式校验(校验input输入框的内容为金额,不能为负数,保留两位小数)

var reg = /(^[1-9]([0-9]+)?(\.[0-9]{1,2})?$)|(^(0){1}$)|(^[0-9]\.[0-9]([0-9])?$)/;

2、输入框限制只能输入数字

Oninput="value=value.replace(/[^0-9]/g,'')"

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/羊村懒王/article/detail/544174
推荐阅读
相关标签
  

闽ICP备14008679号