【tips】动态el-form-item中校验的注意点

场景:

  1. 在el-table中动态渲染了input输入框。输入框是必填项,
  2. 必填校验不通过需要展示红色边框(不需要提示文字)
html 复制代码
<el-table-column v-for="(header, index) in tableHeader" :key="index" :label="header.name"  align="center" :prop="header.code">
<template #default="scope">
 	<el-form-item :prop="`tableRowList.${scope.$index}.${header.code}`" :rules="[{ required: true, message: '', trigger: ['change', 'blur'], validator: validateValue } ]" :show-error="false" class="mb0" label-width="0">
	 <el-input v-model="scope.row[header.code]" placeholder="请输入" size="small"></el-input>
  </el-form-item>
	</template>
</el-table-column>

一般我们校验的做法是,在form的model值中对于属性,在rules进行设置xx

xml 复制代码
 <el-form :model="queryParams_generate" :rules="rules" ref="queryForm" :inline="true" label-width="90px">
<el-form-item :prop="xx" >

而对于动态表格,rules的prop是不一定的,我们valid可以单独设置。

这里的注意点在于:**validateValue 的第二个参数value,如果且xx在model的话,获取value是可以的,但我们目前的:prop="tableRowList.${scope.$index}.${header.code}",不存在model值中,

  1. value值为空,所以要另外获取要检查的输入值val**
javascript 复制代码
// 验证函数:检查数值是否超出限制
const validateValue = (rule, value, callback) => {
    const idx = rule.field?.split('.')?.[1];
    const code = rule.field?.split('.')?.[2];
    const val = tableRowList.value?.[idx]?.[code];

    if (!val) return callback(); // 非必填
    console.log('validateValue', val)
    // if (isNaN(Number(val))) {
    //     return callback(new Error(`非数字`));
    // }
    const numValue = getNum(val);
    const checkResult = checkNumVaildText(numValue);
    if (checkResult) {
        callback(new Error(`数据${checkResult}`));
    } else {
        callback();
    }
};
  1. from.validate调用的返回值valid为true,所以在valid之后要注意再处理动态prop的校验
javascript 复制代码
formRef.value.validate((valid) => {
    if (valid) {
        // 这里另外处理动态prop的校验
        }
 })
相关推荐
Highcharts.js1 小时前
缺失数据可视化图表开发实战|Highcharts创建人员出生统计面积图表示例
开发语言·前端·javascript·信息可视化·highcharts·图表开发
LaughingZhu7 小时前
Product Hunt 每日热榜 | 2026-05-21
前端·人工智能·经验分享·chatgpt·html
怕浪猫8 小时前
Electron 开发实战(一):从零入门核心基础与环境搭建
前端·electron·ai编程
小鹏linux8 小时前
Ubuntu 22.04 部署开源免费具有精美现代web页面的Casdoor账号管理系统
linux·前端·ubuntu·开源·堡垒机
前端若水9 小时前
会话管理:创建、切换、删除对话历史
前端·人工智能·python·react.js
Bigger9 小时前
mini-cc:一个轻量级 AI 编程助手的诞生
前端·ai编程·claude
涵涵(互关)10 小时前
Naive-ui树型选择器只显示根节点
前端·ui·vue
BY组态10 小时前
Ricon组态系统最佳实践:从零开始构建物联网监控平台
前端·物联网·iot·web组态·组态
BY组态10 小时前
Ricon组态系统vs传统组态软件:为什么选择新一代Web组态平台
前端·物联网·iot·web组态·组态
SoaringHeart10 小时前
Flutter进阶:OverlayEntry 插入图层管理器 NOverlayZIndexManager
前端·flutter