el-input限制输入类型

本文介绍如何使用JavaScript和HTML限制输入框的输入类型,包括仅限数字、正整数、正负数及小数,以及如何保留特定位数的小数并进行四舍五入。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

只能输入数字

oninput ="value=value.replace(/[^\d]/g,'')"   //只能输入数字

只能输入数字和小数

oninput ="value=value.replace(/[^0-9.]/g,'')" //只能输入数字和小数

实现输入框只能输入正整数,输入同时禁止了以0开始的数字输入,防止被转化为其他进制的数值。

<input type='text' onkeyup="value=value.replace(/^(0+)|[^\d]+/g,'')">

限制文本框只能输入正数,负数,小数

<input type="text" οnkeyup="value=value.replace(/[^\-?\d.]/g,'')" />

Element-Ui input只允许输入数字和两位小数,保留两位小数(四舍五入),自动补位

<el-form ref="form" :model="form" :rules="formRules" label-width="80px">
 
  <el-form-item label="金额">
    <el-input 
        v-model="form.money" 
        name="money"
        type="text"
        auto-complete="off"
        oninput="value=value.replace(/[^0-9.]/g,'')"  
 
/>
  </el-form-item>
  
</el-form>
<script>
  export default {
    data() {
    const validateMoney = (rule,value,callback) =>{
        if(!value){
            callback(new Error('金额不能为空'))
         }else if(value.split('.').length > 2){
            callback(new Error('输入正确格式的金额')) //防止输入多个小数点
         }else{
            value = Math.round(value * Math.pow(10,2)) / Math.pow(10,2) //四舍五入
            value = Number(value).toFixed(2); //不足补位
            this.form.money = value;
            callback();
            }
};
      return {
        form: {
          money: ''
         
        },
        formRules:{
            money:[
                {required:false,tigger:'blur',validator:validateMoney }
            ]
        }
      }
    },
    methods: {
      
    }
  }
</script>

注:如果想保留n为小数就将 validateMoney 中 else 里面 2改为自己需要的保留位数

 value = Math.round(value * Math.pow(10,2)) / Math.pow(10,2) //四舍五入
 value = Number(value).toFixed(2); //不足补位
### 如何在 `el-input` 中设置输入值范围限制 20 至 99 为了实现 `el-input` 的输入范围限制为 20 到 99,可以通过结合 Vue 的双向绑定机制以及自定义校验逻辑来完成。以下是具体的方法: #### 方法一:通过监听 `oninput` 和正则表达式 可以在 `<el-input>` 上添加 `oninput` 属性,利用 JavaScript 正则表达式过滤非法输入并限定数值范围。 ```html <el-input v-model.number="model.value" type="number" min="20" max="99" oninput="if(value>99)value=99;if(value<20)value=20;value=value.replace(/\D/g,'')" ></el-input> ``` 上述代码实现了以下功能: - 使用 `v-model.number` 确保模型中的值始终为数字类型[^1]。 - 设置属性 `type="number"` 并配合 `min="20"` 和 `max="99"` 来提示用户输入的有效范围[^4]。 - 在 `oninput` 中动态调整超出范围的值,并移除非数字字符[^2]。 --- #### 方法二:通过 `@input` 自定义验证逻辑 如果需要更复杂的校验逻辑,可以绑定 `@input` 事件,在方法中处理输入值。 ```html <el-input v-model.number="model.value" @input="validateInput" placeholder="请输入20至99之间的数字"> </el-input> ``` 对应的验证函数如下: ```javascript methods: { validateInput() { let value = this.model.value; if (isNaN(value) || value < 20 || value > 99) { this.$modal.msgError("请输入有效的数字(20~99)"); this.model.value = ''; // 清空无效输入 } } } ``` 此方法的优势在于能够灵活扩展更多的业务逻辑,比如显示错误提示或阻止提交操作[^3]。 --- #### 方法三:使用 `el-input-number` 替代 虽然题目要求的是 `el-input`,但如果允许替换组件,则推荐使用 `el-input-number` 实现更加直观的效果。 ```html <el-input-number v-model="model.value" :min="20" :max="99" @change="handleInputChange"> </el-input-number> <script> export default { data() { return { model: { value: null }, }; }, methods: { handleInputChange(value) { if (!Number.isInteger(value)) { this.$modal.msgError("请输入有效整数!"); this.model.value = Math.floor(this.model.value); } } } }; </script> ``` 这种方法不仅支持上下按钮调节数值,还内置了对范围和步长的支持[^5]。 --- ### 总结 以上三种方式均可满足需求,其中前两种适用于保留原生 `el-input` 风格的同时增加额外控制;第三种则是借助专门设计用于数值输入的组件简化开发流程。开发者可根据实际场景选择最适合的方式。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值