Vue 自定义rule不生效问题

Vue 自定义rule不生效问题

代码

<template>
  <div id="retrievePassword">
    <div class="me-login-box me-login-box-radius">
      <h1>忘记密码</h1>

      <el-form ref="userForm" :model="userForm" :rules="rules">

         <el-form-item prop="account" v-if="msg">
           <el-input placeholder="账号" v-model="userForm.account"></el-input>
         </el-form-item>

         <el-form-item prop="phone_number" v-if="msg">
           <el-input placeholder="手机号" v-model="userForm.phone_number"></el-input>
         </el-form-item>

         <el-form-item prop="email" v-if="msg">
           <el-input placeholder="邮箱" v-model="userForm.email"></el-input>
         </el-form-item>

        <el-form-item size="small" class="me-login-button" v-if="msg">
          <el-button type="primary" @click.native.prevent="confirm()">确认</el-button>
        </el-form-item>
        <el-form-item size="small" class="me-login-button" v-if="!msg">
          <el-button type="primary" @click.native.prevent="updatePassword()">修改密码</el-button>
        </el-form-item>
        <el-form-item size="small" class="me-return-button">
          <el-button type="primary" @click.native.prevent="gohome()">返回</el-button>
        </el-form-item>
      </el-form>

    </div>
  </div>
</template>

<script>


import md5 from "js-md5";
import Vue from "vue";

export default {
  name: 'Register',
  data() {
    const validatepass = (rule, value, callback) => {
      if(!value){
        Vue.prototype.$message.error("密码不能为空");
        callback(new Error("密码不能为空"));
      } else {
        callback();
      }
    };

    const validatepass2 = (rule, value, callback) => {
      if(!value){
        Vue.prototype.$message.error("确认密码不能为空");
      } else if(value!==this.userForm.password){
        Vue.prototype.$message.error("两次密码不一致");
      } else {

      }
    };

    return {
      msg:1,
      aaa:'',
      userForm: {
        account: '',
        phone_number: '',
        email: '',
        confirm_password:'',
        password:''
      },
      rules: {
        account: [
          {required: true, message: '请输入账号', trigger: 'blur'},
        ],
        phone_number: [
          {required: true, message: '请输入手机号', trigger: 'blur'},
        ],
        email: [
          {required: true, message: '请输入email', trigger: 'blur'},
        ],
        password: [
          {
            required: true,
            message: '请输入密码',
            trigger: 'blur',
            validator: validatepass
          },
        ],
        confirm_password: [
          {
            required: true,
            message: '请再次输入密码',
            trigger: ['blur', 'change'],
            validator: validatepass2
          },
        ]

      }

    }
  },
  methods: {
    confirm() {
      let that = this
      this.$refs.userForm.validate((valid) => {
        if (valid) {
          let finalForm = {
            userAccount: this.userForm.account,
            userPhone: this.userForm.phone_number,
            userEmail: this.userForm.email
          };
        } else {
          return false;
        }
      });
  }
}
</script>

解决方法

有v-if存在时,应在外面建一层div并放到div中,el-form-item会存在冲突,记录一下

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
Vue自定义指令不生效的可能原因有多种。首先,需要明确当前项目使用的Vue版本,因为Vue2和Vue3中的自定义指令的钩子函数是不同的。其次,可能是在自定义指令中存在错误或遗漏,可以通过在directives中添加console语句来检查是否调用了指令。此外,Vue中内置了很多指令,但有时候这些指令无法满足需求,这时候就需要使用自定义指令了。为了确保自定义指令生效,需要在Vue实例中正确注册和使用自定义指令,并确保指令的名称、参数和值正确设置。如果以上步骤都正确,但自定义指令仍然不生效,可能是由于其他代码或配置的影响,需要对代码进行进一步排查和调试。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *2* [自定义指令v-xxx不起作用(指令函数没有被调用);打开页面或跳转到页面自动聚焦输入框](https://blog.csdn.net/qq_45327886/article/details/120865930)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] - *3* [vue自定义指令directive的使用方法](https://download.csdn.net/download/weixin_38720256/14822773)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值