vue3项目对所有输入框进行校验、输入限制

一、数字校验

数字校验在网上找了很多种办法,比如使用 element 里面 el-input 输入框 type属性设置为number,这个可以满足数字的校验,但是如果输入 e 的话是可以输入的,因为 e 在数学中代表一个特殊的实数,所以输入 e 不能代表他是一个bug。

但追求完美的我们肯定不允许这样的存在

二、解决办法

在网上看的很多这种例子,直接加在标签上,这样也可以,但是如果说很多输入框的话,重复代码带多了,最重要的是不好维护。

// 除了数字都不能输入 
 <el-input v-model="form.feeId" @input="form.feeId = String(form.feeId).replace(/[^\d]/g, '')" />

三、最终方案

1.我这里是对金额类输入框和重量类输入框做了校验

  temp = temp.replace(/^(\-)*(\d+)\.(\d{0,2}).*$/, "$1$2.$3");  // 保留两位小数

  temp = temp.replace(/^(\-)*(\d+)\.(\d{0,3}).*$/, "$1$2.$3");  // 保留三位小数

/**
 * @description: 监听所有输入框操作   // 在main.ts下
 * @param {*} input
 * @param {*} function
 * @return {*}
 */
document.addEventListener('input', function (e: any) {
    // 检查输入框是否有 data-type 属性
    const inputType = e.target.getAttribute('data-type');
    let temp = e.target.value.toString();
    temp = temp.replace(/。/g, "."); // 将中文全角句号替换为英文半角句号
    temp = temp.replace(/[^\d.]/g, ""); // 清除"数字"和"."以外的字符
    temp = temp.replace(/^\./g, ""); // 验证第一个字符是数字
    temp = temp.replace(/\.{2,}/g, ""); // 只保留第一个, 清除多余的
    temp = temp.replace(".", "$#$").replace(/\./g, "").replace("$#$", "."); // 只保留第一个小数点
    if (inputType === 'money') {
        temp = temp.replace(/^(\-)*(\d+)\.(\d{0,2}).*$/, "$1$2.$3"); //
        e.target.value = temp
    } else if(inputType === 'weight') {
        temp = temp.replace(/^(\-)*(\d+)\.(\d{0,3}).*$/, "$1$2.$3"); //
        e.target.value = temp
    }
    // 对没有最大长度的进行限制,这个根据后端定义,看自己需求要不要加
    if (e.target.getAttribute('maxlength') === null) {
        e.target.setAttribute('maxlength', '100')  // 限制最长输入100个字符
    }
});

 这里面正则可以根据自己需求进行调整。

2.在组件中通过设置 data-type 属性,进行判断

<el-form-item label="数量(吨):">
   <el-input v-model="info.quantity" data-type="weight"></el-input>
</el-form-item>
  
<el-form-item label="金额(元):">
    <el-input v-model="info.amount"  data-type="money"></el-input>
</el-form-item>

实用!没问题!而且维护起来更方便了。

  • 7
    点赞
  • 9
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
对于 `el-table` 表格中的输入框字段进行校验,可以通过以下步骤实现: 1. 在表格中将要进行校验的字段设置为可编辑的输入框,并绑定一个 `v-model` 指令,用于实时获取输入框的值。 2. 在需要校验的时候,通过正则表达式或其他方式校验输入框的值是否符合要求。 3. 如果输入框的值不符合要求,可以通过 `this.$message` 提示用户输入不合法,并将输入框的值重置为之前的值或者让用户重新输入。 以下是一个简单的示例代码,以手机号码为例进行校验: ```html <template> <el-table :data="tableData" style="width: 100%"> <el-table-column label="姓名" prop="name"></el-table-column> <el-table-column label="手机号码" prop="phone"> <template slot-scope="{ row }"> <el-input v-model="row.phone" @blur="checkPhone(row)"></el-input> </template> </el-table-column> </el-table> </template> <script> export default { data() { return { tableData: [ { name: '张三', phone: '13888888888' }, { name: '李四', phone: '13999999999' }, { name: '王五', phone: '13000000000' } ] } }, methods: { checkPhone(row) { const reg = /^1[3-9]\d{9}$/ // 手机号码正则表达式 if (!reg.test(row.phone)) { this.$message.error('请输入正确的手机号码') row.phone = '' // 重置输入框的值 } } } } </script> ``` 在上面的示例代码中,通过在 `el-input` 组件上绑定 `@blur` 事件,在输入框失去焦点时触发校验手机号码的方法 `checkPhone`。如果手机号码不符合要求,通过 `this.$message` 提示用户输入不合法,并重置输入框的值。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值