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')
  });
}
最终效果图✔✔✔:

posted @ 2023-08-24 11:39  Mahmud(مەھمۇد)  阅读(315)  评论(0编辑  收藏  举报