修改密码和再次确认密码的js和element-ui的使用

js 复制代码
<template>
  <div>
    <!-- plan的插槽 -->
    <plan title="修改密码">
      <!-- 插槽的名字 -->
    <span slot="header">修改密码</span>
    <el-form
      :model="ruleForm2"
      status-icon
      :rules="rules2"
      ref="ruleForm2"
      label-width="100px"
      class="demo-ruleForm"
    >
      <el-form-item label="原密码" prop="oldPwd">
        <el-input v-model="ruleForm2.oldPwd"></el-input>
      </el-form-item>

      <el-form-item label="新密码" prop="newPwd">
        <el-input v-model="ruleForm2.newPwd"></el-input>
      </el-form-item>

      <el-form-item label="确认密码" prop="checkPass">
        <el-input v-model="ruleForm2.checkPass"></el-input>
      </el-form-item>

      <el-form-item>
        <el-button type="primary" @click="submitForm()">提交</el-button>
        <el-button @click="resetForm('ruleForm2')">重置</el-button>
      </el-form-item>
    </el-form>
    </plan>
  </div>
</template>

<script>
import { checkoldpwd, editpwd } from "@/api/account.api";
export default {
  data() {
    // 检查旧密码是否正确
    let validatePass = (rule, value, callback) => {
      checkoldpwd(value).then(res => {
        console.log(res);
        if (res.data.code === 200) {
          callback();
        } else {
          callback(new Error("密码不正确"));
        }
      });
    };

    // 检查新密码
    let validateNewpwd = (rule, value, callback) => {
      if (this.ruleForm2.checkPass) {
        this.$refs.ruleForm2.validateField("checkPass");
      }
      callback();
    };
    // 检查两次密码是否一样
    let validateCheckpwd = (rule, value, callback) => {
      if (value === this.ruleForm2.newPwd) {
        callback();
      } else {
        callback(new Error("密码不一"));
      }
    };

    return {
      ruleForm2: {
        oldPwd: "",
        newPwd: "",
        checkPass: ""
      },
      rules2: {
        oldPwd: [
          { required: true, message: "请输入账号", trigger: "blur" },
          { validator: validatePass, trigger: "blur" }
        ],
        newPwd: [
          { required: true, message: "请输入新密码", trigger: "change" },
          { validator: validateNewpwd, trigger: "change" }
        ],
        checkPass: [
          { required: true, message: "请确认密码", trigger: "change" },
          { validator: validateCheckpwd, trigger: "change" }
        ]
      }
    };
  },
  // 提交验证
  methods: {
    submitForm(formName) {
      this.$refs.ruleForm2.validate(valid => {
        if (valid) {
          editpwd(this.ruleForm2.newPwd).then(res => {
            if (res.data.code === 0) {
              this.$router.push("/login");
            }
          });
        }
      });
    },
    resetForm(formName) {
      this.$refs[formName].resetFields();
    }
  }
};
</script>

<style lang="scss" scoped>
</style>
相关推荐
北极星日淘9 小时前
可买免税店货物与安耐晒——特殊商品代购技术方案
javascript·vue.js·elementui
youyu-youyu10 小时前
oss阿里云图片链接url高清图片设置为缩略图 vue 减少加载体积流量
前端·javascript·vue.js·阿里云·云计算
低保和光头哪个先来10 小时前
聊聊 CSS 编译和 scoped 实现
前端·css·vue.js
_codeOH1 天前
Vue 3 vs React 19:框架还在卷,核心原理就这些
前端·vue.js
英勇无比的消炎药1 天前
新手必看玩转TinyRobot一定要避开这些坑
前端·vue.js
英勇无比的消炎药1 天前
别再盲目混用AI组件库和传统组件库差距原来这么大
前端·vue.js
英勇无比的消炎药1 天前
前端提效神器全新AI组件库TinyRobot改写日常开发模式
前端·vue.js
英勇无比的消炎药1 天前
前端提效神器TinyRobot
前端·vue.js
CDwenhuohuo1 天前
uni 背景色渐变 全屏
前端·javascript·vue.js
爱怪笑的小杰杰1 天前
Vue 项目交付第三方开发,如何隐藏核心 JS 源码?
前端·javascript·vue.js