第一种方式:表单上加rules{object}
<el-form :model="formData" :rules="rule" ref="form">
<el-form-item label="姓名" prop="name">
<el-input v-model="formData.name" placeholder="请输入姓名" clearable></el-input>
</el-form-item>
<el-form-item label="身份证号" prop="IDnum">
<el-input v-model="formData.IDnum" :maxlength="18" placeholder="请输入身份证号" clearable></el-input>
</el-form-item>
</el-form>
这种方式需要在data()中定义rule{},需要在属性prop中写上对应的校验字段,如name写上验证规则,如下:
data() {
return {
formData: {
name: '',
IDnum: ''
},
rule: {
name: [
{ required: true, message: '请输入姓名', trigger: 'blur' },
{ min: 2, max: 10, message: '长度在 2 到 10 个字符', trigger: 'blur' },
{ pattern: /^[\u4e00-\u9fa5_a-zA-Z0-9.·-]+$/, message: '姓名不支持特殊字符', trigger: 'blur'}
],
IDnum: [
{ required: true, message: '请输入身份证号', trigger: 'blur' },
{ min: 15, max: 18, message: '请如实填写18位号码,以供学校保卫科核对', trigger: 'blur' },
{ pattern: /(^\d{15}$)|(^\d{18}$)|(^\d{17}(\d|X|x)$)/, message: '请输入正确的身份证号码', trigger: 'blur' }
]
}
}
}
第二种方式:在el-form-item单个添加
(1) 其中对于有些需要自定义的校验规则可以作为变量写在data中:
<el-form-item label="电话号码" :prop="phoneNum" :rules="rule">
<el-input v-model="formData.phoneNum" :maxlength="11" placeholder clearable></el-input>
</el-form-item>
data() {
return {
formData: {
phoneNum: ""
},
rule: [
{ required: true, message: '请输入电话号码', trigger: 'blur' },
{ required: true, pattern: /^((13|14|15|16|17|18)[0-9]{1}\d{8})|((166|199|198)[0-9]{1}\d{7})$/, message: '请输入正确的电话号码', trigger: 'blur' }]
}
}
(2) 这种方式适用于需要个别检验的字段,或者表单字段有变动的校验;
<el-form-item label="电话号码" :prop="phoneNum" :rules="[{ required: true, message: '请输入电话号码', trigger: 'blur' }, { required: true, pattern: /^((13|14|15|16|17|18)[0-9]{1}\d{8})|((166|199|198)[0-9]{1}\d{7})$/, message: '请输入正确的电话号码', trigger: 'blur' }]">
<el-input v-model="formData.phoneNum" :maxlength="11" placeholder clearable></el-input>
</el-form-item>