修改密码和再次确认密码的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>
相关推荐
用户516816614584115 小时前
Vue Router 路由懒加载引发的生产页面白屏问题
vue.js·vue-router
前端缘梦15 小时前
Vue Keep-Alive 组件详解:优化性能与保留组件状态的终极指南
前端·vue.js·面试
Simon_He15 小时前
这次来点狠的:用 Vue 3 把 AI 的“碎片 Markdown”渲染得又快又稳(Monaco 实时更新 + Mermaid 渐进绘图)
前端·vue.js·markdown
王同学QaQ20 小时前
Vue3对接UE,通过MQTT完成通讯
javascript·vue.js
华仔啊20 小时前
基于 RuoYi-Vue 轻松实现单用户登录功能,亲测有效
java·vue.js·后端
艾小码21 小时前
告别Vue混入的坑!Composition API让我效率翻倍的3个秘密
前端·javascript·vue.js
Gracemark2 天前
高德地图-地图选择经纬度问题【使用输入提示-使用Autocomplete进行联想输入】(复盘)
vue.js
天下无贼2 天前
【手写组件】 Vue3 + Uniapp 手写一个高颜值日历组件(含跨月补全+今日高亮+选中状态)
前端·vue.js
洋葱头_2 天前
vue3项目不支持低版本的android,如何做兼容
前端·vue.js
奔跑的蜗牛ing2 天前
Vue3 + Element Plus 输入框省略号插件:零侵入式全局解决方案
vue.js·typescript·前端工程化