el-input输入限制(只能输入0-100的正整数,最小值~最大值联动)

  1. 只能输入0-100的正整数
  2. 最小值~最大值联动
  3. <el-input
      style="width: 70px"
      :formatter="formatInput"
      :parser="parseInput"
      @blur="checknum('min', inputData, 'value1', inputData.value2)"
      v-model.number="value"
      placeholder="最小值"
    />
    ~~
    <el-input
      style="width: 70px"
      :formatter="formatInput"
      :parser="parseInput"
      @blur="checknum('max', inputData, 'value2', inputData.value1)"
      v-model.number="value"
      placeholder="最大值"
    />
    
    
    const formatInput = (value) => {
      // 格式化输入的值,保留数字部分
      return value.replace(/^0+(\d)|[^\d]+/g, '')
    }
    const parseInput = (value) => {
      // 解析输入的值,将其转换为合法的数字
      let numValue = parseInt(value, 10)
      if (isNaN(numValue)) return '' // 处理输入非数字的情况
      // 限制输入的最小值和最大值
      return Math.max(0, Math.min(100, numValue)).toString()
    }
    //最小值~最大值
    const checknum = (type, inputData, field, otherValue) => {
      let numValue = parseInt(inputData[field], 10) || 0
      if (type == 'max') {
        if (numValue < otherValue) {
          n
### 设置 `el-input` 只允许输入非负整数 为了使 `el-input` 组件仅接受非负整数(包括0),可以采用多种方法来实现这一目标。一种常见的方式是在 HTML 属性中加入正则表达式的处理逻辑,以阻止任何不符合条件的字符被录入。 对于非负整数的情况,下面这段代码展示了如何配置 `el-input` 来达到目的: ```html <el-input v-model="value" type="number" clearable placeholder="请输入非负整数" min="0" @blur="handleBlur(value)" onKeypress="return (/[\d]/.test(String.fromCharCode(event.keyCode)))"> </el-input> ``` 上述代码通过设置 `type="number"` 和 `min="0"` 确保用户无法提交小于零的数值[^2]。同时,在失去焦点事件(`@blur`)触发时调用了自定义函数 `handleBlur()` 对最终值做进一步验证和修正;另外还利用了内联 JavaScript 表达式过滤掉所有非数字键入。 此外,也可以考虑使用更简洁的方法,即直接在 `v-model` 后面加上 `.number` 修饰符,并配合 `oninput` 事件监听器移除非数字字符: ```html <el-input v-model.number="value" oninput="value=value.replace(/[^\d]/g,'')"> </el-input> ``` 这种方法同样能有效地防止非法字符进入输入框并自动转换字符串类型的输入为数值型[^1]。 最后值得注意的是,虽然这些前端措施有助于改善用户体验,但在实际应用开发过程中仍需结合服务器端校验机制共同保障数据的有效性和安全性。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

嫣嫣细语

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值