前言
这几天在修改别人的代码时。发现了父子通信的表单提交验证,一看,自己都懵了,怎么用了表单,但是提交的时候全写些判断呢,没办法了,只能改了!
element表单验证提交
1.基础表单验证提交
<el-form :model="numberValidateForm" ref="numberValidateForm" label-width="100px" class="demo-ruleForm">
<el-form-item
label="年龄"
prop="age"
:rules="[
{ required: true, message: '年龄不能为空'},
{ type: 'number', message: '年龄必须为数字值'}
]"
>
<el-input type="age" v-model.number="numberValidateForm.age" autocomplete="off"></el-input>
</el-form-item>
<el-form-item>
<el-button type="primary" @click="submitForm('numberValidateForm')">提交</el-button>
<el-button @click="resetForm('numberValidateForm')">重置</el-button>
</el-form-item>
</el-form>
<script>
export default {
data() {
return {
numberValidateForm: {
age: ''
}
};
},
methods: {
submitForm(formName) {
this.$refs[formName].validate((valid) => {
if (valid) {
alert('submit!');
} else {
console.log('error submit!!');
return false;
}
});
},
resetForm(formName) {
this.$refs[formName].resetFields();
}
}
}
</script>
像这里的提交都是用的validate
2.带正则的表单验证
刚开始我也像element-ui提供的方法那样写,自定义校验规则的那个列子,但发现用validate提交的时候没有反应,已打印才知道根本没有进入到那一步。贴上代码:
后面查看文档知道单独写的验证可能需要进行部分校验,需要用的validateField,把需要校验的字段,传到方法里,如下
this.$refs.formData.validateField(['marter','code'], (valid)=>{
console.log("拿到东西了吗,进入",valid)
if(!valid){
alert("可以")
}else{
alert("不可以")
}
})
但这样会执行方法两次,并且不能做的我们理想的表单验证方式。
3.完美的表单验证提交
可以把分开写的正则融入到rules里面,element有个属性pattern,专门用来做正则的表单验证,代码如下:
在这里插入代码片
rules:{
packageSize: [{ message: "字段长度不合格!", trigger: "blur",pattern: /^[1-9]\d{0,6}(\.\d{1,3})?$|^0(\.\d{1,3})?$/ }],
}
在提交的时候也不需要用到validateField,直接跟最普通的提交方法一样,用validate
this.$refs.formData.validate((valid)=>{
console.log("拿到东西了吗,进入",valid)
if(valid){
alert("可以")
}else{
alert("不可以")
}
})