首先有一个这样的需求,表单中默认有一个联系人信息,用户可以再添加新的联系人信息
点击添加更多联系人之后
官方文档中有写用v-for来实现新增表单,但是那是单表单的新增,现在多表单的新增,可以考虑的实现方法是先写死一个必须的表单,需要新增的两个表单放在一个div里,在div中使用v-for生成,达到同时新增的效果
代码如下
//必填一个联系人的表单 <el-form-item class="rules" label="通知对象:" prop="notifyobject"> <el-input v-model="ruleForm.notifyobject" placeholder="请输入联系人名称" :disabled="isReadonly" class="el-select_box"></el-input> </el-form-item> <el-form-item class="rules" label="邮箱:" prop="email"> <el-input v-model="ruleForm.email" placeholder="请输入邮箱" :disabled="isReadonly" class="el-select_box"></el-input> </el-form-item> //动态生成的联系人表单 <div class="moreRules"> <div class="moreRulesIn" v-for="(item, index) in ruleForm.moreNotifyObject" :key="item.key"> <el-form-item class="rules" label="通知对象:" :prop="'moreNotifyObject.' + index +'.notifyobject'" :rules="moreNotifyOjbectRules.moreNotifyOjbectName"> <el-input v-model="item.notifyobject" placeholder="请输入联系人名称" :disabled="isReadonly" class="el-select_box"></el-input> </el-form-item> <el-form-item class="rules" label="邮箱:" :prop="'moreNotifyObject.'+ index +'.email'" :rules="moreNotifyOjbectRules.moreNotifyOjbectEmail"> <el-input v-model="item.email" placeholder="请输入邮箱" :disabled="isReadonly" class="el-select_box"></el-input> </el-form-item> <el-button @click="deleteRules(item, index)" :disabled="isReadonly">删除</el-button> </div> </div> <el-form-item v-show="!isRead"> <el-button type="text" class="addUser" @click="addUser" :disabled="isReadonly"><i class="iconfont icon-tianjialianxiren"></i>添加更多联系人</el-button> </el-form-item>
和普通表单验证不同的是,动态表单要新增自己的验证规则,和添加普通表单的方式一样
ruleForm:{ //普通表单的验证规则 }, //新增表单的验证规则 moreNotifyOjbectRules: { moreNotifyOjbectName: [{ required: true, message: '请输入联系人名称', trigger: 'blur' }, { validator: (rule, value, callback) => { if (value.length > 15 || value.length < 2) { callback(new Error('长度必须为2~8个字符')) } else { var reg = new RegExp("[`~!@#$^&*()=|{}':',\\[\\].<>《》/?~!@#¥……&*()——|{}【】‘;:”“'。,、?]") if (reg.test(value)) { callback(new Error('不能含有特殊字符')) } else { callback() } } }, trigger: 'change' } ], moreNotifyOjbectEmail: [{ required: true, message: '请输入邮箱地址', trigger: 'blur' }, { type: 'email', message: '请输入正确的邮箱地址', trigger: 'blur' } ] }
这里需要注意的是:rules是每个表单都要都要添加的,有多个的话就要给每个表单绑定一个规则
<el-form-item class="rules" label="通知对象:" :prop="'moreNotifyObject.' + index +'.notifyobject'" :rules="moreNotifyOjbectRules.moreNotifyOjbectName"> <el-form-item class="rules" label="邮箱:" :prop="'moreNotifyObject.'+ index +'.email'" :rules="moreNotifyOjbectRules.moreNotifyOjbectEmail">
另外要注意的是:prop,正常表单验证单项是依靠prop,但是动态生成话要用:prop。
书写的语法是:prop="'moreNotifyObject.' + index +'.notifyobject'",moreNotifyObject是v-for绑定的数组,index是索引,notifyobject是表单绑定的v-model的名称,然后用.把他们链接起来。
所以总结起来的语法就是:prop="'v-for绑定的数组.' + index + '.v-model绑定的变量'"
还有一个需要注意就是v-for的写法,要将表单的model名写进去
<div class="moreRulesIn" v-for="(item, index) in ruleForm.moreNotifyObject" :key="item.key">
还有要注意的就是v-for绑定的数组也要在表单的对象里,写在表单对象外是验证不了的,在data里添加
ruleform:{ moreNotifyObject: [{ notifyobject: '', email: '' }] }
然后新增联系人的函数应该这样写
addUser() { this.ruleForm.moreNotifyObject.push({ notifyobject: '', email: '' }) }
同理删除联系人也是
deleteRules(item, index) { this.index = this.ruleForm.moreNotifyObject.indexOf(item) if (index !== -1) { this.ruleForm.moreNotifyObject.splice(index, 1) } }
如果一开始只想让默认必填的表单显示,而新增的不显示,如文章最开头的表现一样,则可以在methods中初始化v-for绑定的数组
methods:{ //初始化数据 initData(){ this.ruleFrom.moreNotifyObject = [] }}
总结
以上所述是小编给大家介绍的Vue+Element实现动态生成新表单并添加验证功能,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对小牛知识库网站的支持!
问题内容: 我正在使用“ revalidate”来验证“ redux- form”表单,但是我面对这种情况,其中存在一个基于我在其上映射并在表单内显示输入的API响应动态生成的表单。 这是我通常如何使用“重新验证…”验证“ redux表单”的示例 现在,如何使用自动生成的表单执行类似的操作? 问题答案: 这个想法是让从它是第二个参数的功能,并请你来填充验证使用它们。 由于是一个高阶函数,因此在运行
本文向大家介绍vue+vue-validator 表单验证功能的实现代码,包括了vue+vue-validator 表单验证功能的实现代码的使用技巧和注意事项,需要的朋友参考一下 官方文档:http://vuejs.github.io/vue-validator/zh-cn/index.html github项目地址:https://github.com/vuejs/vue-validator 下
本文向大家介绍JavaScript实现表单验证功能,包括了JavaScript实现表单验证功能的使用技巧和注意事项,需要的朋友参考一下 本文实例为大家分享了JavaScript实现表单验证功能的具体代码,供大家参考,具体内容如下 以下是JavaScript的表单验证功能,可根据JS代码编写出你想要的HTML和CSS的代码。 关于正则表达式的使用,以及常用的正则表达式,笔者目前还在整理中,后期整理完
本文向大家介绍使用Vue生成动态表单,包括了使用Vue生成动态表单的使用技巧和注意事项,需要的朋友参考一下 开需求会了,产品说这次需求的表单比较多,目前有18个,后期的表单可能会有增加、修改。我作为这次的前端开发,看到这样的需求,心里知道要这样搞不得把自己累死,首先表单居多,还会有变更,以后维护起来也让人心力憔悴。 于是我提议做动态表单,做一个表单的配置系统,在系统里配置表单类型、表单得字段、以及
本文向大家介绍vue iview实现动态路由和权限验证功能,包括了vue iview实现动态路由和权限验证功能的使用技巧和注意事项,需要的朋友参考一下 github上关于vue动态添加路由的例子很多,本项目参考了部分项目后,在iview框架基础上完成了动态路由的动态添加和菜单刷新。为了帮助其他需要的朋友,现分享出实现逻辑,欢迎一起交流学习。 Github地址 iview-dynamicRouter
本文向大家介绍AngularJS实现表单手动验证和表单自动验证,包括了AngularJS实现表单手动验证和表单自动验证的使用技巧和注意事项,需要的朋友参考一下 AngularJS的表单验证大致有两种,一种是手动验证,一种是自动验证。 一、手动验证 所谓手动验证是通过AngularJS表单的属性来验证。而成为AngularJS表单必须满足两个条件: 1、给form元素加上novalidate="no