elementUI表单项动态添加校验方法

要实现element动态表单项需要使用v-for标签,关键点是 :rules=“item.rules”

表单:

<el-form ref="form" :model="form" >
	<el-form-item 
		v-for="(item,index) in form.list " 
		:prop="item.prop" 
		:label="item.label" 
		:rules="item.rules" 
		:key="index">
	</el-form-item>
</el-form>

data数据:

data(){
	return{
		form:{
			list:[{prop:'',label:'',rules:[]}]
		},
		//校验对象
        //校验必输项
        checkRequired:{required: true, message: "此项为必填项,不能为空", trigger: "blur"},
        //校验长度
        checkLong:{ min: 3, max: 5, message: '长度在 3 到 5 个字符', trigger: 'blur' },
        //校验日期
        checkDate:{ type: 'date', required: true, message: '请选择日期', trigger: 'change' }
	};
}

methods:

methods:{
	//动态添加校验规则
	addRules(){
		let colRules =[]
		if(判断条件){
			colRules.push(this.checkRequired)
		}
		if(判断条件){
			colRules.push(this.checkDate)
		}
		this.form.list.push({prop:'birthday',label:'生日',rules:colRules})
	}
}

如果想添加自定义校验方法也是可以的,即在data(){}里添加校验方法,在return{}里声明,然后在方法里使用,详情见:https://blog.csdn.net/dong4hang_CSDN/article/details/122009067

  • 0
    点赞
  • 9
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值