vue2使用el-form动态参数展示并非空校验

需求:需要根据类型type动态显示某些参数,并且后端需要的参数也不同,比如type为1:后端要aa和bb参数,type为2:后端要cc和dd参数,前端显示的字段名也不一样,但是样式是不变的。

1.效果

2.主要代码讲解

因为vue的限制,所以需要使用this.$set让数组变为响应式,不然会导致输入框输入不了

      handleChange(value) {let params = {1: [{label: '姓名',name: ''},{label: '年龄',age: ''}],2: [{label: '开始时间',start: ''},{label: '结束时间',end: ''}]};this.$set(this.formObj, 'paramsList', params[value]);},

这句话的意思就是在对象中找到不是label的属性

 v-model="formObj.paramsList[index][Object.keys(item).find((key) => key !== 'label')]"

可以打印一下输出,结果是name

   let aa = Object.keys({label: '姓名',name: ''}).find((key) => key !== 'label');console.log(aa);//name

3.完整代码

<!--* @Description:* @Author: 请叫我欧皇i* @Date: 2025-04-27 14:56:56* @FilePath
-->
<template><div style="margin-top: 40px"><el-select v-model="selectedOptions" clearable placeholder="请选择" @change="handleChange"><el-option v-for="item in options" :key="item.value" :label="item.label" :value="item.value"> </el-option></el-select><el-form :model="formObj" ref="addBaseRef" label-width="95px" class="demo-ruleForm add-point-form" style="margin: 40px 0px"><el-descriptions labelClassName="labelClassName" direction="vertical" :column="5" border style="width: 500px"><el-descriptions-item :label="item.label" v-for="(item, index) in formObj.paramsList" :key="item.label" :span="1"><el-form-item:prop="`paramsList[${index}].${Object.keys(item).find((key) => key !== 'label')}`":rules="[{required: true,message: '',trigger: 'blur',message: `请输入${item.label}`}]"label-width="0px"><el-inputstyle="width: 167px"size="small"v-model="formObj.paramsList[index][Object.keys(item).find((key) => key !== 'label')]":placeholder="`请输入${item.label}`"></el-input></el-form-item></el-descriptions-item></el-descriptions></el-form><el-button type="primary" @click="submitForm('addBaseRef')">立即创建</el-button></div>
</template><script>
export default {data() {return {formObj: {paramsList: []},selectedOptions: 1,options: [{value: 1,label: '参数1'},{value: 2,label: '参数2'}]};},mounted() {this.handleChange(this.selectedOptions);},methods: {handleChange(value) {let params = {1: [{label: '姓名',name: ''},{label: '年龄',age: ''}],2: [{label: '开始时间',start: ''},{label: '结束时间',end: ''}]};this.$set(this.formObj, 'paramsList', params[value]);},submitForm(formName) {this.$refs[formName].validate((valid) => {if (valid) {alert('submit!');} else {console.log('error submit!!');return false;}});}}
};
</script><style lang="scss" scoped></style>

文章到此结束希望对你有所帮助~

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

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

相关文章

(附源码)基于Vue的教师档案管理系统的设计与实现

摘 要 随着信息技术的不断发展&#xff0c;学校管理工作正逐渐从纸质化向数字化转型。教师档案管理作为学校管理的重要环节&#xff0c;其信息化和高效化对于提升学校管理水平具有重要意义。本文设计并实现了一个基于Vue框架的教师档案管理系统&#xff0c;旨在通过前端技术的…

运算电源抑制比(PSRR)测量及设计注意事项

1、简介如果运放的供电电源发生变化&#xff0c;输出不应发生变化&#xff0c;但实际运放随着供电电源的波动&#xff0c;运放输出也将会发生波动。折合到输出端&#xff0c;PSRR定义 Xv(电源电压波动) / Yv&#xff08;输出电压波动&#xff09;&#xff0c;该量为无量纲&…

YOLOv8-SMOT:一种高效鲁棒的实时小目标跟踪框架:基于切片辅助训练与自适应关联

https://arxiv.org/pdf/2507.12087 摘要 从无人机&#xff08;UAV&#xff09;视角对小型敏捷多目标&#xff08;SMOT&#xff09;——例如鸟类——进行跟踪是一项极具挑战性的计算机视觉任务。该任务的难点主要源于三个方面&#xff1a;目标外观特征极度稀缺、相机与目标自身复…

深入理解QLabel:Qt中的文本与图像显示控件

在Qt框架中&#xff0c;QLabel是一个功能强大且灵活的控件&#xff0c;主要用于在用户界面上显示文本或图像。无论是在简单的信息提示&#xff0c;还是在复杂的图形界面中&#xff0c;QLabel都能发挥重要作用。本文将详细介绍QLabel的主要功能、使用方法以及一些高级技巧&#…

hintcon2025 Verilog OJ

#web题目要求我们执行 /readflag give me the flagif ((strcmp(argv[1], "give") | strcmp(argv[2], "me") | strcmp(argv[3], "the") | strcmp(argv[4], "flag")) ! 0) {puts("You are not worthy");return 1; }首先&#…

佳易王钟表维修养护管理系统:开启钟表维修高效管理新篇章​就#软件操作教程

前言&#xff1a; &#xff08;一&#xff09;试用版获取方式 资源下载路径&#xff1a;进入博主头像主页第一篇文章末尾&#xff0c;点击卡片按钮&#xff1b;或访问左上角博客主页&#xff0c;通过右侧按钮获取详细资料。 说明&#xff1a;下载文件为压缩包&#xff0c;使用…

mysql组提交

Binlog Group Commit1. 背景&#xff1a;没有组提交时的问题&#xff08;MySQL 5.7及更早版本的痛点&#xff09;在早期版本的MySQL中&#xff0c;为了保证二进制日志&#xff08;Binlog&#xff09; 和 存储引擎&#xff08;如InnoDB&#xff09; 之间的一致性&#xff08;即一…

C#简单组态软件开发

C#简单组态软件开发 组态软件(SCADA/HMI)是工业自动化领域的核心软件&#xff0c;用于监控和控制工业过程。 系统架构设计 一个基本的组态软件应包含以下模块&#xff1a; 图形界面编辑器设备通信模块实时数据库运行时引擎报警系统历史数据存储 开发环境搭建开发工具&#xff1…

Maya绑定:人物绑定详细案例(创建骨骼、镜像骨骼、IK创建、IK打组、IK控制器、FK控制器、烘焙动画、导出)

目录 壹 创建骨骼 1 准备一个模型 2 创建骨骼 腿部骨骼 躯体骨骼 嘴巴骨骼 披风骨骼 手臂骨骼 手指骨骼 3 给骨骼命名 4 调整关节的坐标轴 测试 5 镜像骨骼 贰 控制器 一 脚部控制 IK 1 脚部IK创建 腿部IK 脚掌IK 2 脚部IK打组 动作1&#xff1a;脚掌着地&…

手写MyBatis第46弹:多插件责任链模式的实现原理与执行顺序奥秘--MyBatis插件架构深度解析

&#x1f942;(❁◡❁)您的点赞&#x1f44d;➕评论&#x1f4dd;➕收藏⭐是作者创作的最大动力&#x1f91e;&#x1f496;&#x1f4d5;&#x1f389;&#x1f525; 支持我&#xff1a;点赞&#x1f44d;收藏⭐️留言&#x1f4dd;欢迎留言讨论&#x1f525;&#x1f525;&am…

宜春城区光纤铺设及接口实地调研

一、研究方向与近期关注 因为课题研究的原因&#xff0c;最近对城市骨干网非常感兴趣。前期我讨论了5G&#xff0c;WiFi及自组网等无线通信网络情况&#xff0c;感兴趣的朋友可以移步我的博客阅读&#xff1a; 5G无线通信网络场景&#xff08;日常、工业&#xff09;及拓扑结…

Tomcat 企业级运维实战系列(六):综合项目实战:Java 前后端分离架构部署

Tomcat 企业级运维实战系列&#xff08;六&#xff09;&#xff1a;综合项目实战&#xff1a;Java 前后端分离架构部署一&#xff1a;概述二&#xff1a;部署1&#xff09;环境准备2&#xff09;部署数据库3&#xff09;部署后端4&#xff09;部署前端总结&#x1f680; Tomcat…

《Unity Shader入门精要》学习笔记四(高级纹理)

1、立方体纹理解释&#xff1a;站在一个完全透明的玻璃盒子中心&#xff0c;就可以看到6个面。把这个玻璃盒子的6个面都贴上一张照片。这6张照片合起来&#xff0c;就记录了周围360度的环境&#xff0c;比如蓝天、地面、建筑、树木等。在2D纹理中&#xff0c;使用坐标来找颜色&…

局域网中使用Nginx部署https前端和后端

目录 一.前端部署https 二.后端部署https 一.前端部署https 1.前端正常创建项目即可,打包后,文件夹的格式是dist 2.下载认证的证书 也可以使用其他软件,这里推荐使用mkcert,下载地址如下: Releases FiloSottile/mkcert GitHub 3.输入 mkcert -install

K8s卷机制:数据持久化与共享

在 Kubernetes&#xff08;K8s&#xff09;中&#xff0c;卷&#xff08;Volume&#xff09; 是用于解决容器内数据持久化、容器间数据共享以及与外部存储交互的核心机制。它本质上是一个可供 Pod 中容器访问的存储目录&#xff0c;生命周期独立于容器&#xff08;容器重启或销…

线性回归原理推导与应用(十一):多重共线性

多重共线性的定义与影响 多重共线性&#xff08;Multicollinearity&#xff09;是指线性回归模型中的解释变量之间由于存在精确相关关系或高度相关关系而使模型估计失真或难以估计准确。 根据定义和影响程度&#xff0c;可以将多重共线性分为极端共线性和一般共线性。极端共线…

day082-初识ElasticStack

文章目录0. 老男孩思想-人性十大需求1. ElasticStack介绍1.1 ELK&#xff08;**Elastic Stack**&#xff09;1.2 logstash和filebeat的区别2. ElasticSearch单点部署2.1 下载ElasticSearch软件包2.2 安装软件并修改配置文件2.3 启动并测试服务3. ElasticSearch集群部署3.1 安装…

软考 系统架构设计师系列知识点之杂项集萃(139)

接前一篇文章:软考 系统架构设计师系列知识点之杂项集萃(138) 第257题 系统工程利用计算机作为工具,对系统的结构、元素、()和反馈等进行分析,以达到最优()、最优设计、最优管理和最优控制的目的。霍尔(A.D.Hall)于1969年提出了系统方法的三维结构体系,通常称为霍…

solidity地址、智能合约、交易概念

目录地址address 的两种子类型&#xff08;Solidity 0.5.0&#xff09;address分类address 的常用操作和属性总结交易交易的基本结构&#xff08;由外部发起&#xff09;Gas交易生命周期函数调用与交易常见交易场景总结地址 在 Solidity 中&#xff0c;地址&#xff08;addres…

jwt原理及Java中实现

一、JWT 是什么&#xff1f;解决什么问题&#xff1f; 我们先来一张图看一下这个过程&#xff1a;JWT&#xff08;JSON Web Token&#xff09;是一种把“认证信息&#xff08;Claims&#xff09; 完整性校验”打包成 自包含 的字符串的规范。 它主要用于无状态认证&#xff1a;…