vue+element-ui效验两次输入的密码是否一致

vue+element-ui效验两次输入的密码是否一致

1. 表单

 		<el-form
            :model="ruleForm"
            :rules="rules"
            ref="ruleFormRef"
          	>
			<el-form-item prop="pass" label="密码:">
                <el-input
                  prefix-icon="el-icon-my-lock"
                  show-password
                  placeholder="请输入新密码(8-16位数字及字母)"
                  maxlength="16"
                  type="password"
                  v-model="ruleForm.pass"
                  autocomplete="off"
                ></el-input>
            </el-form-item>
            <el-form-item prop="checkPass" label="确认密码:">
                <el-input
                  prefix-icon="el-icon-my-lock"
                  show-password
                  placeholder="确认密码(8-16位数字及字母)"
                  maxlength="16"
                  type="password"
                  v-model="ruleForm.checkPass"
                  autocomplete="off"
                ></el-input>
            </el-form-item>
       </el-form>

2. 自定义效验规则

	data() {
	    let validatePass = (rule, value, callback) => {
	      let reg = new RegExp(/[A-Za-z].*[0-9]|[0-9].*[A-Za-z]/);
	      if (value === "") {
	        callback(new Error("请输入密码"));
	      } else if (value.length < 8 || !reg.test(value)) {
	        callback(new Error("请输入含数字和字母的8-16位密码"));
	      } else {
	        if (this.ruleForm.checkPass !== "") {
	          this.$refs.ruleFormRef.validateField("checkPass");
	        }
	        callback();
	      }
	    };
	    let validatePass2 = (rule, value, callback) => {
	      if (value === "") {
	        callback(new Error("请再次输入密码"));
	      } else if (value !== this.ruleForm.pass) {
	        callback(new Error("两次输入密码不一致!"));
	      } else {
	        callback();
	      }
	    };
	    return {
	      //表单数据
	      ruleForm: {
	        pass: "",
	        checkPass: "",
	      },
	      //效验规则
	      rules: {
	        pass: [{ required: true, validator: validatePass, trigger: "blur" }],
	        checkPass: [
	          { required: true, validator: validatePass2, trigger: "blur" },
	        ],
	      },
	    };
	  },
  • 0
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值