没有合适的资源?快使用搜索试试~ 我知道了~
首页Vue+Element实现动态生成新表单并添加验证功能
Vue+Element实现动态生成新表单并添加验证功能
4.9k 浏览量
更新于2023-05-26
评论
收藏 55KB PDF 举报
主要介绍了Vue+Element实现动态生成新表单并添加验证功能,本文通过实例代码给大家介绍的非常详细,具有一定的参考借鉴价值,需要的朋友可以参考下
资源详情
资源评论
资源推荐

Vue+Element实现动态生成新表单并添加验证功能实现动态生成新表单并添加验证功能
主要介绍了Vue+Element实现动态生成新表单并添加验证功能,本文通过实例代码给大家介绍的非常详细,具有
一定的参考借鉴价值,需要的朋友可以参考下
首先有一个这样的需求,表单中默认有一个联系人信息,用户可以再添加新的联系人信息
点击添加更多联系人之后
官方文档中有写用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()
}
}
},



















weixin_38706294
- 粉丝: 4
- 资源: 918
上传资源 快速赚钱
我的内容管理 收起
我的资源 快来上传第一个资源
我的收益
登录查看自己的收益我的积分 登录查看自己的积分
我的C币 登录后查看C币余额
我的收藏
我的下载
下载帮助

会员权益专享
最新资源
- Xilinx SRIO详解.pptx
- Informatica PowerCenter 10.2 for Centos7.6安装配置说明.pdf
- 现代无线系统射频电路实用设计卷II 英文版.pdf
- 电子产品可靠性设计 自己讲课用的PPT,包括设计方案的可靠性选择,元器件的选择与使用,降额设计,热设计,余度设计,参数优化设计 和 失效分析等
- MPC5744P-DEV-KIT-REVE-QSG.pdf
- 通信原理课程设计报告(ASK FSK PSK Matlab仿真--数字调制技术的仿真实现及性能研究)
- ORIGIN7.0使用说明
- 在VMware Player 3.1.3下安装Redhat Linux详尽步骤
- python学生信息管理系统实现代码
- 西门子MES手册 13 OpcenterEXCR_PortalStudio1_81RB1.pdf
资源上传下载、课程学习等过程中有任何疑问或建议,欢迎提出宝贵意见哦~我们会及时处理!
点击此处反馈



安全验证
文档复制为VIP权益,开通VIP直接复制

评论0