vue结合elementUI自定义表单校验规则避雷

vue结合elementUI自定义表单校验规则避雷

callback和return陷阱

  • 自定义校验规则中不能直接写return,比如if(!value)return;必须返回一个回调函数callback()(返回callback的入参为空代表校验通过规则,返回含new Error(‘自定义提示’)入参代表校验不通过规则。)
  • 必须保证自定义校验规则的每个分支都调用了callback方法,否则会导致el-form组件的validate方法无法进入回调函数。

this.$refs[formName].validate

  1. 使用此方法前检查prop一定必须要写在上面,写在里面的input上或者其他任何地方都不行(*el-form-item prop属性绑定*

  2. el-form rules,model属性绑定,ref标识

template:

<div>
  <el-form ref="loginForm" :model="form" :rules="rules" label-width="80px" class="login-box">
    <h3 class="login-title">欢迎登录</h3>
    <el-form-item label="账号" prop="username">
      <el-input type="text" placeholder="请输入账号" v-model="form.username"/>
    </el-form-item>
    <el-form-item label="密码" prop="password">
      <el-input type="password" placeholder="请输入密码" v-model="form.password"/>
    </el-form-item>
    <el-form-item>
      <el-button type="primary" v-on:click="onSubmit('loginForm')">登录</el-button>
    </el-form-item>
  </el-form>
</div>

script:

export default {
  name: "Login",
  data(){
    //   自定义校验规则
    var checkUsername = (login,value,callback)=>{
      if(!value)
        return callback(new Error('用户名不能为空 '));
      //   自定义校验规则

      callback();
    };
    var checkPassword = (login,value,callback)=>{
      if(!value)
        return callback(new Error('密码不能为空 '));
      if(value.length < 6){
        return callback(new Error('密码不能小于6位 '));
      }
      callback();
    };
    return{
      form:{
        username:'',
        password:''
      },
      //表单验证,需要在 el-form-item 元素中增加prop属性
      rules:{
        username:[
          //   validator: 验证
          //   trigger: 触发
          //   required: 必填项
          {validator:checkUsername,trigger:"blur",required:true}
        ],
        password:[
          {validator:checkPassword,trigger:"blur",required:true}
        ]
      },

    }
  }
}

展示:

全部代码: 包含了提交提示框的代码

<template>
  <div>
    <el-form ref="loginForm" :model="form" :rules="rules" label-width="80px" class="login-box">
      <h3 class="login-title">欢迎登录</h3>
      <el-form-item label="账号" prop="username">
        <el-input type="text" placeholder="请输入账号" v-model="form.username"/>
      </el-form-item>
      <el-form-item label="密码" prop="password">
        <el-input type="password" placeholder="请输入密码" v-model="form.password"/>
      </el-form-item>
      <el-form-item>
        <el-button type="primary" v-on:click="onSubmit('loginForm')">登录</el-button>
      </el-form-item>
    </el-form>

    <el-dialog title="温馨提示" :visible.sync="dialogVisible" width="30%" :before-close="handleClose">
      <span>请输入账号和密码</span>
      <span slot="footer" class="dialog-footer">
          <el-button type="primary" @click="dialogVisible = false">确定</el-button>
        </span>
    </el-dialog>
  </div>
</template>

<script>
export default {
  name: "Login",
  data(){
    //   自定义校验规则
    var checkUsername = (login,value,callback)=>{
      if(!value)
        return callback(new Error('用户名不能为空 '));
      //   自定义校验规则

      callback();
    };
    var checkPassword = (login,value,callback)=>{
      if(!value)
        return callback(new Error('密码不能为空 '));
      if(value.length < 6){
        return callback(new Error('密码不能小于6位 '));
      }
      callback();
    };
    return{
      form:{
        username:'',
        password:''
      },
      //表单验证,需要在 el-form-item 元素中增加prop属性
      rules:{
        username:[
          //   validator: 验证
          //   trigger: 触发
          //   required: 必填项
          {validator:checkUsername,trigger:"blur",required:true}
        ],
        password:[
          {validator:checkPassword,trigger:"blur",required:true}
        ]
      },

      //对话框显示和隐藏
      dialogVisible:false
    }
  },
  methods:{
    onSubmit(formName){
      //为表单绑定验证功能
      this.$refs[formName].validate((valid)=>{
        if(valid){
          //使用vue-router路由到指定界面,该方式称为编程式导航
          this.$router.push('/main/'+this.username);
        }else{
          this.dialogVisible=true;
          return false;
        }
      });
    },
    handleClose(done) {
      /*this.$confirm('确认关闭?')
        .then(_ => {
          done();
        })
        .catch(_ => {});*/
    }
  }
}
</script>

<style lang="scss" scoped>
.login-box{
  border:1px solid #DCDFE6;
  width: 350px;
  margin:180px auto;
  padding: 35px 35px 15px 35px;
  border-radius: 5px;
  -webkit-border-radius: 5px;
  -moz-border-radius: 5px;
  box-shadow: 0 0 25px #909399;
}
.login-title{
  text-align:center;
  margin: 0 auto 40px auto;
  color: #303133;
}
</style>

posted @ 2021-12-03 20:58  恸的池塘  阅读(578)  评论(0编辑  收藏  举报