动态循环表单+动态判断表单类型+动态判断表单是否必填方法

news2025/4/10 19:28:48

页面效果:

接口请求到的数据格式:

        list: [
                {
                    demandType: "设备辅助功能要求",
                    demandSettingList: [
                        {
                            id: "1907384788664963074",
                            name: "测试表单",
                            fieldType: 0,
                            contentValue: "",
                            vaildStatus: 0, // 0 非必填;1 必填
                        }
                    ]
                },
                {
                    demandType: "与产品接触部件要求",
                    demandSettingList: [
                        {
                            id: "1907384788648185858",
                            name: "需求背景",
                            fieldType: 0,
                            contentValue: "",
                            vaildStatus: 1
                        }
                    ]
                },
            ]

模版代码:

            <div v-for="(item,index) in list" :key="index">
                <el-form :inline="true" :model="item" :ref="'form' + index" label-width="100px">
                    <div class="demand-type">{{ item.demandType }}</div>
                    <div v-for="(itm,index2) in item.demandSettingList" :key="index2">
                        <!-- fieldType: 0---文本类型表单 -->
                        <el-form-item :label="itm.name" v-if="itm.fieldType === 0" :prop="'demandSettingList.' + index2 + '.contentValue'" 
                        :rules="{ required: itm.vaildStatus === 1, message: itm.name + '不能为空', trigger: 'blur' }">
                            <el-input v-model="itm.contentValue" placeholder="请输入" style="width:200px"></el-input>
                        </el-form-item>
                        <!-- fieldType: 1---数字类型表单 -->
                        <el-form-item :label="itm.name" v-if="itm.fieldType === 1" :prop="'demandSettingList.' + index2 + '.contentValue'" 
                        :rules="{ required: itm.vaildStatus === 1 }">
                            <el-input-number v-model="itm.contentValue" :min="1" style="width:200px"></el-input-number>
                        </el-form-item>
                        <!-- fieldType: 2---日期类型表单 -->
                        <el-form-item :label="itm.name" v-if="itm.fieldType === 2" :prop="'demandSettingList.' + index2 + '.contentValue'" 
                        :rules="{ required: itm.vaildStatus === 1 }">
                            <el-date-picker v-model="itm.contentValue" type="date" placeholder="请选择日期"
                                    format="yyyy-MM-dd" value-format="yyyy-MM-dd" style="width:200px">
                            </el-date-picker>
                        </el-form-item>
                        <!-- fieldType: 3---时间类型表单 -->
                        <el-form-item :label="itm.name" v-if="itm.fieldType === 3" :prop="'demandSettingList.' + index2 + '.contentValue'" 
                        :rules="{ required: itm.vaildStatus === 1 }">
                            <el-date-picker v-model="itm.contentValue" type="datetime" style="width:200px"
                            format="yyyy-MM-dd HH:mm:ss" value-format="yyyy-MM-dd HH:mm:ss" placeholder="选择时间"></el-date-picker>
                        </el-form-item>
                        <!-- fieldType: 4---人员单选类型表单 -->
                        <el-form-item :label="itm.name" v-if="itm.fieldType === 4" :prop="'demandSettingList.' + index2 + '.contentValue'" 
                        :rules="{ required: itm.vaildStatus === 1 }">
                            <el-select v-model="itm.contentValue" filterable remote placeholder="请选择" style="width:200px"
                                @focus="userFoucs" :remote-method="remoteMethod" :loading="loadingSearch">
                                <el-option v-for="it in searchUserList" :key="it.id" :label="`${it.realName}(${it.account})`"
                                    :value="it.id">
                                </el-option>
                            </el-select>
                        </el-form-item>
                        <!-- fieldType: 5---人员多选类型表单 -->
                        <el-form-item :label="itm.name" v-if="itm.fieldType === 5" :prop="'demandSettingList.' + index2 + '.contentValue'" 
                        :rules="{ required: itm.vaildStatus === 1 }">
                            <el-select v-model="itm.contentValue" filterable remote placeholder="请选择" style="width:200px"
                                multiple collapse-tags @focus="userFoucs" :remote-method="remoteMethod" :loading="loadingSearch">
                                <el-option v-for="it in searchUserList" :key="it.id" :label="`${it.realName}(${it.account})`"
                                    :value="it.id">
                                </el-option>
                            </el-select>
                        </el-form-item>
                    </div>
                </el-form>
            </div>
            <div style="text-align: center;display: block;" v-if="rightFormList.length != 0">
                <el-button type="primary" @click="submitForm()" :loading="loadingBtn">确定</el-button>
            </div>

提交时的校验方法:

        submitForm() {
            this.$nextTick(() => {
                const formRefs = Object.values(this.$refs)
                    .flat()
                    .filter(ref => ref && typeof ref.validate === "function"); // 过滤非 el-form 组件

                if (formRefs.length === 0) {
                    console.warn("未找到任何 el-form 组件,请检查 v-for 绑定的 ref 是否正确");
                    return;
                }

                Promise.all(formRefs.map(form => form.validate()))
                    .then(() => {
                        this.loadingBtn = false;
                        let list = [];
                        this.rightFormList.forEach(item => {
                            item.demandSettingList.forEach(itm => {
                                list.push(itm);
                            });
                        });
                        return api.queryProjectDemandSettingUpdate(list, this.uuId);
                    })
                    .then(() => {
                        this.$message.success('操作成功!');
                        this.getRightList();
                        this.getUuid();
                    })
                    .catch(() => {
                        this.loadingBtn = false;
                        this.$message.warning("请完整填写必填信息!");
                    });
            });
        },

📌 总结

📢 代码执行流程

  1. 使用 this.$nextTick() 确保 this.$refs 获取到最新的 el-form 组件

  2. 收集 this.$refs 里的 el-form 组件,并确保 .validate() 方法存在

  3. Promise.all() 让所有表单执行 .validate()

    • 如果全部校验通过,调用 API 提交数据。

    • 如果有未填写的必填项,则提示用户补充信息。

🛠 可能的问题

validate is not a function

原因

  • this.$refs["form" + index] 可能是 数组undefined

  • 解决方案

    • 使用 this.$refs["form" + index][0] 或者 遍历 this.$refs 过滤非 el-form 组件(即代码里 .filter(ref => typeof ref.validate === "function") 部分)。

❌ 提交后还是提示“请完整填写必填信息”

可能原因

  • el-form-item:prop 绑定错误,导致 validate() 无法正确校验。

  • v-model 绑定的 contentValue 可能是 undefined,导致 required 校验失败。

检查方案

  1. 确保 el-form-item:prop 写对:

    <el-form-item :prop="'demandSettingList.' + index2 + '.contentValue'"
  2. 确保 itm.contentValue 初始值是 ""null(不要是 undefined)。

至此完成!!!

测试有效!!!感谢支持!!!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/2328043.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

25.4.3学习总结【Java】

又是一道错题&#xff1a; 1. 班级活动https://www.lanqiao.cn/problems/17153/learning/?page1&first_category_id1&sortdifficulty&asc1&second_category_id3 问题描述 小明的老师准备组织一次班级活动。班上一共有 n 名 (n 为偶数) 同学&#xff0c;老师…

运维之 Centos7 防火墙(CentOS 7 Firewall for Operations and Maintenance)

运维之 Centos7 防火墙 1.介绍 Linux CentOS 7 防火墙/端口设置&#xff1a; 基础概念&#xff1a; 防火墙是一种网络安全设备&#xff0c;用于监控和控制网络流量&#xff0c;以保护计算机系统免受未经授权的访问和恶意攻击。Linux CentOS 7操作系统自带了一个名为iptables的…

开发一个小程序需要多久时间?小程序软件开发周期

开发一个小程序所需时间受多种因素影响&#xff0c;以下为你详细列举&#xff1a; 一、需求复杂度。若只是简单展示类小程序&#xff0c;如企业宣传、产品介绍&#xff0c;功能单一&#xff0c;大概 1 - 2 周可完成。若涉及复杂交互&#xff0c;像电商小程序&#xff0c;涵盖商…

【数据结构篇】算法征途:穿越时间复杂度与空间复杂度的迷雾森林

文章目录 【数据结构篇】算法征途&#xff1a;穿越时间复杂度与空间复杂度的迷雾森林 一、 什么是算法1. 算法的定义1.1 算法的五个特征1.2 好算法的特质 2. 时间复杂度3. 空间复杂度 【数据结构篇】算法征途&#xff1a;穿越时间复杂度与空间复杂度的迷雾森林 &#x1f4ac;欢…

新增帧能耗指标|UWA Gears V1.0.9

UWA Gears 是UWA最新发布的无SDK性能分析工具。针对移动平台&#xff0c;提供了实时监测和截帧分析功能&#xff0c;帮助您精准定位性能热点&#xff0c;提升应用的整体表现。 本次版本更新主要新增帧能耗指标&#xff0c;帮助大家对每一帧的能耗进行精准监控&#xff0c;快速…

蓝桥杯嵌入式16届———LCD模块

LCD有官方给我们提供的库&#xff0c;我们使用其非常简单&#xff0c;唯一要注意的就是LCD和LED的引脚冲突。 引脚状况 STM32CubeMX 端口配置 使能 比赛给的选手 资源数据包中有以下三个文件&#xff0c;&#xff08;除去led相关的&#xff09;&#xff0c;将他们复制到自己…

CMake在Windows环境下Visual Studio Code的使用

1&#xff0c;安装下载 地址&#xff1a;Visual Studio Code - Code Editing. Redefined 双击安装 选择安装路径 可勾选微软的AI工具 2&#xff0c;环境介绍 2.1 &#xff0c;界面介绍 2.2中文包的安装 下载中文简体 汉化后的界面 2.3 配置C/C环境 VSCode安装好之后&#xf…

注意力机制在大语言模型中的原理与实现总结

注意力机制在大语言模型中的原理与实现总结 1. 章节介绍 在大语言模型的学习中&#xff0c;理解注意力机制至关重要。本章节旨在深入剖析注意力机制的原理及其在大语言模型中的应用&#xff0c;为构建和优化大语言模型提供理论与实践基础。通过回顾神经网络基础及传统架构的局…

大模型学习三:DeepSeek R1蒸馏模型组ollama调用流程

一、说明 目前DeepSeek R1及其蒸馏模型均支持使用ollama进行调用&#xff0c;可以在模型主页查看调用情况 deepseek-r1https://ollama.com/library/deepseek-r1 显存需求 &#xff0c;我们显存是16G&#xff0c;可以玩好几个 二、以14B模型演示 1、安装ollama curl -fsSL htt…

RAGFlow部署与使用介绍-深度文档理解和检索增强生成

ragflow部署与使用教程-智能文档处理与知识管理的创新引擎 1. ragflow简介 ​ RAGFlow作为新一代智能文档处理平台&#xff0c;深度融合检索增强生成&#xff08;RAG&#xff09;技术与自动化工作流引擎&#xff0c;为企业级知识管理提供全栈解决方案。通过结合多模态解析、语…

【AI赋能:58招聘数据的深度剖析之旅】

影刀出鞘&#xff0c;抓取数据 在当今数字化时代&#xff0c;数据分析已成为企业决策和发展的关键驱动力。而获取高质量的数据则是数据分析的首要任务。在这个信息爆炸的时代&#xff0c;网络上蕴含着海量的数据&#xff0c;其中招聘网站的数据对于人力资源分析、市场趋势研究…

几何法证明卡特兰数_栈混洗

模型&#xff1a; 考虑从坐标原点 (0, 0) 到点 (n, n) 的路径&#xff0c;要求路径只能向右&#xff08;x 方向&#xff09;或向上&#xff08;y 方向&#xff09;移动&#xff0c;并且路径不能越过直线 y x&#xff08;即始终满足 y< x &#xff09;。这样的路径数量就是…

Kafka的安装与使用(windows下python使用等)

一、下载 可以去官网下载&#xff1a;https://kafka.apache.org/downloads 版本可选择&#xff0c;建议下载比较新的&#xff0c;新版本里面自带zookeeper 二、安装 创建一个目录&#xff0c;此处是D:\kafka&#xff0c;将文件放进去解压 如果文件后缀是gz&#xff0c;解压…

数据结构初阶: 顺序表的增删查改

顺序表 概念 顺序表是⽤⼀段物理地址连续的存储单元依次存储数据元素的线性结构&#xff0c;⼀般情况下采⽤数组存储。如图1&#xff1a; 顺序表和数组有什么区别&#xff1f; 顺序表的底层是用数组实现的&#xff0c;是对数组的封装&#xff0c;实现了增删查改等接口。 分…

详解AI采集框架Crawl4AI,打造智能网络爬虫

大家好&#xff0c;Crawl4AI作为开源Python库&#xff0c;专门用来简化网页爬取和数据提取的工作。它不仅功能强大、灵活&#xff0c;而且全异步的设计让处理速度更快&#xff0c;稳定性更好。无论是构建AI项目还是提升语言模型的性能&#xff0c;Crawl4AI都能帮您简化工作流程…

【爬虫开发】爬虫开发从0到1全知识教程第14篇:scrapy爬虫框架,介绍【附代码文档】

本教程的知识点为&#xff1a;爬虫概要 爬虫基础 爬虫概述 知识点&#xff1a; 1. 爬虫的概念 requests模块 requests模块 知识点&#xff1a; 1. requests模块介绍 1.1 requests模块的作用&#xff1a; 数据提取概要 数据提取概述 知识点 1. 响应内容的分类 知识点&#xff1a…

SQLark:一款国产免费数据库开发和管理工具

SQLark&#xff08;百灵连接&#xff09;是一款面向信创应用开发者的数据库开发和管理工具&#xff0c;用于快速查询、创建和管理不同类型的数据库系统&#xff0c;目前可以支持达梦数据库、Oracle 以及 MySQL。 对象管理 SQLark 支持丰富的数据库对象管理功能&#xff0c;包括…

防爆对讲机VS非防爆对讲机,如何选择?

在通信设备的广阔市场中&#xff0c;对讲机以其高效、便捷的特点&#xff0c;成为众多行业不可或缺的沟通工具。而面对防爆对讲机与非防爆对讲机&#xff0c;许多用户常常陷入选择困境。究竟该如何抉择&#xff0c;且听我为您细细道来。 防爆对讲机&#xff0c;专为危险作业场…

微信小程序开发:开发实践

微信小程序开发实践研究 摘要 随着移动互联网的迅猛发展&#xff0c;微信小程序作为一种轻量化、无需安装的应用形式&#xff0c;逐渐成为开发者和用户的首选。本文以“个人名片”小程序为例&#xff0c;详细阐述了微信小程序的开发流程&#xff0c;包括需求分析、项目规划、…

操作 Office Excel 文档类库Excelize

Excelize 是 Go 语言编写的一个用来操作 Office Excel 文档类库&#xff0c;基于 ECMA-376 OOXML 技术标准。可以使用它来读取、写入 XLSX 文件&#xff0c;相比较其他的开源类库&#xff0c;Excelize 支持操作带有数据透视表、切片器、图表与图片的 Excel 并支持向 Excel 中插…