1. el-form 校验多个指定字段,不校验整个表单;2. 同时校验多个表单

1. el-form 校验多个指定字段,不校验整个表单

// 校验两个字段
const requiredFields = ['sname', 'phone']
// 记录通过校验的字段数量
let count = 0
requiredFields.forEach((item) => {
	this.$refs.addForm.validateField(item, (errorMsg) => {
		if (errorMsg) {
			return
		}
		count++
	})
})
// 判断必填字段的数量,与检验通过的数量,是否一致
const flag = count === requiredFields.length
if (!flag) {
	this.$message.error('姓名、手机号不能为空!')
	return
}
// 保存接口
this.saveApi()

第二种

const errArray = []
await this.$refs.ruleFormRef.validateField(['url', 'datepicker'], (errMsg, fieldConfig) => {
	  if (errMsg) {
	    errArray.push(fieldConfig)
	  }
})
if (errArray.length > 0) {
  // empty
} else {
  Modal.alert('日期和url通过校验')
}

2. 同时校验多个表单

// 验证表单
validForm(refName) {
	return new Promise((resolve, reject) => {
		// 表单不存在也继续
		if (!this.$refs[refName]) {
			resolve()
		} else {
			this.$refs[refName].validate((valid) => {
				console.log(refName, valid)
				!valid ? reject() : resolve()
			})
		}
	})
},
// 此方法也适用于多个步骤中含有多个表单,只会校验当前步骤的表单
saveForm() {
	Promise.all([ this.validForm('addForm'), this.validForm('editForm') ])
			.then(res => {
				try {
					this.saveApi()
				} catch (error) {
					this.$message.error('出错了!')
				}
			}).catch(() => {
				this.$message.error('请完善表单!')
			})
}

  • 2
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
当一个el-form-item多个el-input的表单校验时,可以使用数组的方式为每个el-input设置不同的校验规则。下面是一个示例: ```html <template> <el-form ref="form" :model="formData" :rules="formRules" label-width="100px"> <el-form-item label="用户名" prop="username"> <el-input v-model="formData.username"></el-input> </el-form-item> <el-form-item label="密码" prop="password"> <el-input v-model="formData.password" type="password"></el-input> </el-form-item> <el-form-item> <el-button type="primary" @click="submitForm">提交</el-button> </el-form-item> </el-form> </template> <script> export default { data() { return { formData: { username: '', password: '' }, formRules: { username: [ { required: true, message: '请输入用户名', trigger: 'blur' }, { min: 3, max: 10, message: '用户名长度在 3 到 10 个字符', trigger: 'blur' } ], password: [ { required: true, message: '请输入密码', trigger: 'blur' }, { min: 6, max: 20, message: '密码长度在 6 到 20 个字符', trigger: 'blur' } ] } }; }, methods: { submitForm() { this.$refs.form.validate(valid => { if (valid) { // 表单校验通过,执行提交操作 // ... } else { // 表单校验不通过,显示错误信息 return false; } }); } } }; </script> ``` 在上面的示例中,我们为每个el-input设置了不同的校验规则。通过在formRules对象中为每个字段设置一个数组,数组中的每个对象表示一个校验规则。每个校验规则对象包含了校验规则的配置,例如required、min、max等,以及对应的错误提示信息和触发校验的事件。在submitForm方法中,我们使用this.$refs.form.validate方法来触发表单校验,并根据校验结果执行相应的操作。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值