Form表单验证
Form组件提供了表单验证的功能,需要通过rules属性
传入约定的验证规则,并将Form-Item
的prop属性
设置为需校验的字段名
1. 使用方法
结构:
<template>
<div>
<el-form :model="loginForm" status-icon :rules="loginRules" ref="loginForm" label-width="100px"
class="demo-ruleForm">
<el-form-item label="电话" prop="phone">
<el-input v-model.number="loginForm.phone" placeholder="请输入电话" prefix-icon="el-icon-phone" />
</el-form-item>
<el-form-item label="密码" prop="password">
<el-input type="password" v-model="loginForm.password" placeholder="请输入密码" prefix-icon="el-icon-lock"
show-password></el-input>
</el-form-item>
<el-form-item>
<el-button type="primary" @click="handleLogin">登录</el-button>
</el-form-item>
</el-form>
</div>
</template>
数据解释:
- v-model:表单数据绑定
- status-icon:(布尔属性)
当设置为 true 时,表单字段在验证后会显示一个状态图标:
✅ 绿色对勾:表示验证通过
❌ 红色错误:表示验证失败- :rules=“loginRules”:绑定loginRules验证规则
- ref:用来获取表单组件,手动触发验证
- label:表单名
- props: (表单验证)表单对象loginForm中的数据名
如果验证失败,ElementUI 会 自动 在<el-form-item>
下方显示错误信息(message),而 prop 就是找到数据对应规则的桥梁。- prefix-icon:图标
- show-password:出现小眼睛可点击密码是否可见
逻辑:
export default {
data() {
const validatePhone = (rule, value, callback) => {
if (!value) {
return callback(new Error('电话不能为空'));
} else {
const regPhone = /^(13[0-9]|14[01456879]|15[0-35-9]|16[2567]|17[0-8]|18[0-9]|19[0-35-9])\d{8}$/;
if (!regPhone.test(value)) {
callback(new Error('请输入正确的手机号'));
} else {
callback();
}
}
};
return {
loginForm: {
phone: '',
password: '',
},
loginRules: {
phone: [
{ required: true, validator: validatePhone, message: '请输入正确手机号', trigger: 'blur' }
],
password: [
{ required: true, massage: '输入密码', trigger: 'blur' },
{ min: 6, max: 20, message: '长度在6到20个字符', trigger: 'blur' }
]
}
}
},
methods: {
handleLogin() {
this.$refs.loginForm.validate((valid) => {
if (valid) {
this.loading = true;
alert('登陆成功!');
} else {
return false;
}
})
}
}
}
loginRules中每个表单项可以包含多条校验规则{},第一条若不符合则之后的校验规则则不执行
validate()方法是组件内置的,用来对表单内容进行验证
2. rule参数
参数 | 类型 | 说明 | 示例 |
---|---|---|---|
type |
String | 字段类型 | 邮箱验证:{ type: 'email' } |
required |
Boolean | 是否必填 | { required: true } |
message |
String/Function | 错误提示 | { message: '必填项' } |
trigger |
String/Array | 触发事件 | { trigger: ['blur', 'change'] } |
参数 | 说明 | 示例 |
---|---|---|
pattern |
正则表达式验证 | { pattern: /^1\d{10}$/ } |
min/max |
数值/长度范围 | { min: 6, max: 12 } |
len |
固定长度 | { len: 11 } |
enum |
枚举值验证 | { enum: ['admin', 'user'] } |
whitespace |
禁止纯空格 | { whitespace: true } |
validator |
自定义验证函数 | {validator:validatePhone} |
密码强度验证:
{ pattern: /^(?=.*\d)(?=.*[a-z])(?=.*[A-Z]).{8,}$/, message: '需包含大小写和数字' }
3. validator回调函数
validator: (rule, value, callback) => {
// 验证逻辑
if (/* 验证失败条件 */) {
callback(new Error('错误提示信息'));
} else {
callback();
}
}
- rule:Object (当前验证规则对象,包含该字段的所有验证规则信息)
- value:当前表单字段的值
- callback:验证完成后的回调函数
- 验证成功时调用:
callback();
- 验证失败时调用:
callback(new Error('错误提示信息'))
异步服务器验证
username: [
{required:true,message:'请输入用户名'},
{
validator:(rule,value,callback)=>{
checkUsernameAvaliable(value).then(available=>{
if(!available){
callback(new Error('用户名已存在'));
}else{
callback();
}
});
},
trigger:'blur'
}
]