element表单校验(注册密码-确认密码)~提交🔑🔒
💎目标界面:
1.引入elementUI组件,路由和axios配置
2.实现表单页面布局
<!-- 注册的表单区域 -->
<el-form :model="regForm" :rules="regRules" ref="regForm" label-width="10px" class="demo-ruleForm">
<el-form-item prop="name">
<el-input v-model="regForm.name" placeholder="请输入用户名" prefix-icon="el-icon-user"></el-input>
</el-form-item>
<el-form-item prop="password">
<el-input v-model="regForm.password" placeholder="请输入密码" prefix-icon="el-icon-lock"></el-input>
</el-form-item>
<el-form-item prop="repassword">
<el-input v-model="regForm.repassword" placeholder="请确认密码" prefix-icon="el-icon-lock"></el-input>
</el-form-item>
<el-form-item>
<el-form-item>
<el-button class="btn-reg" type="primary" @click="reg(regForm)">注册</el-button>
</el-form-item>
<el-form-item>
<el-button type="text">去登录</el-button>
</el-form-item>
</el-form-item>
</el-form>
return {
regForm:{
name:'',
password:'',
repassword: ''
},
rules:{}
}
效果图:
3.添加Rules校验规则
regRules:{
name:[
{ required: true,message:'请输入用户名称',trigger:'blur', },
// {min:2,max:5,message: '用户名称长度是2-5字符之间',trigger: 'blur'}
// pattern: 指定正则来匹配
{ pattern: /^[a-zA-Z][a-zA-Z0-9]{0,9}$/, message: '用户名必须是1 ~ 10位的字母或数字, 不能以数字开头', trigger: 'blur' }
],
password:[
{ required: true,message:'请输入密码',trigger:'blur', },
// {min:6,max:15,message: '密码长度是6-15字符之间',trigger: 'blur'}
// pattern: 指定正则来匹配
{ pattern: /^\S{6,15}$/, message: '密码必须是6 ~ 15位的非空字符', trigger: 'blur' }
],
repassword:[
{ required: true,message:'请输入密码',trigger:'blur', },
// {min:6,max:15,message: '密码长度是6-15字符之间',trigger: 'blur'}
// pattern: 指定正则来匹配
{ pattern: /^\S{6,15}$/, message: '密码必须是6 ~ 15位的非空字符', trigger: 'blur' },
{ validator:checkPwd, trigger: 'blur'} //验证-两次密码一直
]
},
效果图:
4.判断校验是否通过
// data下面写:element 官网在这里写, 我们就模仿
// 参数1:rule规则对象一般不用
// 参数2:value当前校验项的数据对象
// 参数3:callback 回调函数,决定校验是否通过:直接调用不传参说明校验通过,调用传染错误对象说明校验失败!
var checkPwd = (rule, value, callback) => {
if (value === '') {
callback(new Error('请再次输入密码'));
} else if (value !== this.regForm.password) {
callback(new Error('两次输入密码不一致!'));
} else {
callback();
}
}
5.提交表单数据-发送请求
查看代码
reg(regForm){
// this.$refs[regForm].validate((valid) => {
// valid 是校验是否通过的结果:true是通过,false没通过
this.$refs.regForm.validate(async (valid) => {
if (!valid) return
console.log('注册')
const {data:res } = await this.$http.post('/api/reg',{
username:this.regForm.name,
password:this.regForm.password,
repassword:this.regForm.repassword
})
if (res.code !== 0){
return this.$message.error(res.message)
}
this.$message.success(res.message)
console.log(res)
this.$router.push('/login')
});
}