Element-UI 实现动态增加多个输入框并校验

文章目录

  • 前言
  • 实现通过按钮动态增加表单并验证必填
  • 实现动态多个输入框为行内模式,其它为行外模式


前言

在做复杂的动态表单,实现业务动态变动,比如有一条需要动态添加的el-form-item中包含了多个输入框,并实现表单验证,但在element-ui组件库中给出的表单校验中没有这样的格式,想要实现这个功能就来跟我一起学习吧。


实现通过按钮动态增加表单并验证必填

先上实现效果图:

在这里插入图片描述

实现代码如下:

<el-form-item v-for="(item, index) in form.settings" :key="index" :label="'设置' + (index + 1)"><el-form-item label="名称" :prop="'settings.'+index+'.name'" :rules="[{ required: true, message: '必填项', trigger: 'change' }]" label-width="50px"><el-input v-model.trim="item.name" style="width: 100px" /></el-form-item><el-form-item label="" :prop="'settings.'+index+'.val'" :rules="[{ required: true, message: '必填项', trigger: 'change' }]" label-width="50px"><el-input v-model.trim="item.val" style="width: 100px" /></el-form-item><el-form-item label="key" :prop="'settings.'+index+'.key'" :rules="[{ required: true, message: '必填项', trigger: 'change' }]" label-width="50px"><el-input v-model.trim="item.key" style="width: 100px" /></el-form-item><el-form-item><el-button @click.prevent="removeSetting(item)">删除</el-button></el-form-item>
</el-form-item>
<el-form-item label=" "><el-button icon="el-icon-circle-plus-outline" @click="addSetting()">新增设置</el-button>
</el-form-item>

实现思路

el-form-item 中嵌套 el-form-item ,只需要拼接一下prop就可以直接使用校验:

  • :prop=“‘settings.’+index+‘.name’”
    • settings 是for循环取值的数组
    • name 是输入框双向绑定的值
  • :rules=“[{ required: true, message: ‘必填项’, trigger: ‘change’ }]”
    • 校验规则中需要校验的数组

加入以下方法可动态增删表单:

removeSetting(item) {var index = this.form.settings.indexOf(item)if (index !== -1) {this.form.settings.splice(index, 1)}
},
addSetting() {this.form.settings.push({'name': '','key': '','val': ''})
},

实现动态多个输入框为行内模式,其它为行外模式

效果如图:

在这里插入图片描述

实现思路

el-form 定义 :inline="true" 实现行内模式,以便于动态增加的多个输入框在同一行显示;再通过 Layout 布局 将其它比较小的单个输入框控制在一个行内,通过 row 和 col 组件,并通过 col 组件的 span 属性我们就可以自由地组合布局。

实现代码如下:

<el-form ref="form" :inline="true" :model="form" :rules="rules" size="small" label-width="120px"><el-row><el-col :span="24"><el-form-item label="test1" prop="teest1"><el-input v-model.trim="form.test1" style="width: 220px" /></el-form-item></el-col><el-col :span="24"><el-form-item label="test2" prop="test2"><el-input v-model.trim="form.test2" style="width: 220px" /></el-form-item></el-col><el-col :span="24"><el-form-item label="test3" prop="test3"><el-input v-model.trim="form.test3" style="width: 220px" /></el-form-item></el-col><el-col :span="24"><el-form-item v-for="(item, index) in form.settings" :key="index" :label="'设置' + (index + 1)"><el-form-item label="名称" :prop="'settings.'+index+'.name'" :rules="[{ required: true, message: '必填项', trigger: 'change' }]" label-width="50px"><el-input v-model.trim="item.name" style="width: 100px" /></el-form-item><el-form-item label="" :prop="'settings.'+index+'.val'" :rules="[{ required: true, message: '必填项', trigger: 'change' }]" label-width="50px"><el-input v-model.trim="item.val" style="width: 100px" /></el-form-item><el-form-item label="key" :prop="'settings.'+index+'.key'" :rules="[{ required: true, message: '必填项', trigger: 'change' }]" label-width="50px"><el-input v-model.trim="item.key" style="width: 100px" /></el-form-item><el-form-item><el-button @click.prevent="removeSetting(item)">删除</el-button></el-form-item></el-form-item></el-col><el-col :span="24"><el-form-item label=" "><el-button icon="el-icon-circle-plus-outline" @click="addSetting()">新增设置</el-button></el-form-item></el-col></el-row>
</el-form>

如果本文帮到了你,不妨点个赞吧~ ❤❤❤

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

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

相关文章

CTFHub XSS DOM跳转 WriteUp

前文&#xff1a;DOM反射XSS 进入网站&#xff0c;直接查看源代码&#xff0c;下面是关键代码&#xff0c;这里有xss漏洞&#xff1a; <script>var target location.search.split("")if (target[0].slice(1) "jumpto") {location.href target[1…

vue项目中的vue.config.js配置文件中的proxy代理post一直在预检

记录一个比较有意思的bug,帮别人调试遇到的&#xff0c;一个哥们一直在群里问了好几次同一个问题了&#xff0c;他配置了代理&#xff0c;请求一直在发送&#xff0c;postman测试没问题&#xff0c;可以成功接收到&#xff0c;但是在项目前端请求&#xff0c;确实一点响应没有&…

Qt/C++原创项目作品精选(祖传原创/性能凶残)

00 前言说明 从事Qt开发十年有余&#xff0c;一开始是做C#.NET开发的&#xff0c;因为项目需要&#xff0c;转行做嵌入式linux开发&#xff0c;在嵌入式linux上做可视化界面开发一般首选Qt&#xff0c;当然现在可选的方案很多比如安卓&#xff0c;但是十多年前那时候板子性能低…

Nginx常用配置及和基本功能讲解

Nginx已经广泛应用于J-one和Jdos的环境部署上&#xff0c;本文对Nginx的常用的配置和基本功能进行讲解&#xff0c;适合Ngnix入门学习。 一、核心配置 找到Nginx安装目录下的conf目录下nginx.conf文件&#xff0c;Nginx的基本功能配置是由它提供的。 配置文件结构 Nginx的配…

linux中安装nginx

2.安装nginx 2.1 安装nginx前&#xff0c;需要安装的依赖&#xff08;可能是由于nginx版本旧原因&#xff0c;可能最新或较新版本不需安装这些依赖&#xff09; 如下四个依赖需要安装到linux中 2.1.1 安装 pcre 依赖 &#xff08;使用wget命令&#xff09; 步骤一&#xff1…

由中序及后序遍历序列构建二叉树的函数参数解析

【二叉树构建函数的参数确立示意图】 ile&#xff1a;中序遍历左端点位置&#xff0c;iri&#xff1a;中序遍历右端点位置 ple&#xff1a;后序遍历左端点位置&#xff0c;pri&#xff1a;后序遍历右端点位置 【函数代码】 int build(int ile,int iri,int ple,int pri){int ro…

MySql存储引擎介绍——InnoDB、MyISAM、Memory

文章目录 1.MySql体系结构2.存储引擎简介3.存储引擎的特点3.1 InnoDB存储引擎特点3.2 MyISAM存储引擎介绍3.3 Memory存储引擎介绍 4.三种存储引擎的特点5.存储引擎的选择6.小结 1.MySql体系结构 2.存储引擎简介 存储引擎就是存储数据、建立索引、更新/查询数据等技术的实现方式…

基于springboot+mybatis-plus+mysql+vue音乐网站管理系统

基于springbootmybatis-plusmysqlvue音乐网站管理系统 一、系统介绍1、系统主要功能&#xff1a;2.涉及技术框架&#xff1a;3.项目说明&#xff1a; 二、功能展示三、其它系统四、获取源码 一、系统介绍 1、系统主要功能&#xff1a; 音乐播放 用户登录注册 用户信息编辑、头…

Failed to start connector [Connector[HTTP/1.1-8080]]

1、解决Web server failed to start. Port 8080 was already in use 2、SpringBoot启动报错:“Error starting ApplicationContext. To display the conditions report re-run your application with ‘debug’ enabled.” 3、Failed to start end point associated with Proto…

这所985太好考了,专硕06方向仅刷一人,其余过线全收!

一、学校及专业介绍 东北大学&#xff08;Northeastern University&#xff09;位于辽宁省沈阳市&#xff0c;是中华人民共和国教育部直属全国重点大学。它是国家“双一流”建设高校、国家“211工程”和“985工程”重点建设高校&#xff0c;全国首批博士、硕士学位授予单位。 …

RabbitMQ 常用 API

RabbitMQ 常用 API Connection 和 Channel 的创建、关闭 创建 Connection ConnectionFactory factory new ConnectionFactory(); // 方式1&#xff1a;通过设置参数创建 factory.setHost(IP_ADDRESS); factory.setPort(PORT); factory.setUsername("guest"); facto…

【AJAX】使用JQ发送AJAX发送请求

首先要引入JQ <script crossorigin"anonymous" src"https://cdn.staticfile.org/jquery/1.10.2/jquery.min.js"></script>服务端代码 // 服务端准备 // 1、引入express const express require(express); // 2、创建应用对象 const app expr…