<template>
<div class="app-container common-list-page">
<el-form
:model="resetForm"
:rules="resetFormRules"
ref="resetForm"
status-icon
label-width="100px"
>
<el-form-item label="旧密码:" prop="password">
<el-input type="password" v-model="resetForm.password" auto-complete="off"></el-input>
</el-form-item>
<el-form-item label="新密码:" prop="newpwd">
<el-input type="password" v-model="resetForm.newpwd" auto-complete="off"></el-input>
</el-form-item>
<el-form-item label="确认密码:" prop="newpassword1">
<el-input type="password" v-model="resetForm.newpassword1" auto-complete="off"></el-input>
</el-form-item>
<el-form-item>
<el-button type="primary" @click.native.prevent="toAmend">确认修改</el-button>
</el-form-item>
</el-form>
</div>
</template>
<script>
import api from "@/api";//这是我个人全局定义单独用来接收url接口的文件,不作参考
import { getUsername } from "@/utils/auth";//这是我个人调用封装获取当前账户的username,不作参考
export default {
data() {
var validatePass = (rule, value, callback) => {
if (!value) {
callback(new Error("请输入新密码"));
} else if (value.toString().length < 6 || value.toString().length > 18) {
callback(new Error("密码长度为6-18位"));
} else {
callback();
}
};
var validatePass2 = (rule, value, callback) => {
if (value === "") {
callback(new Error("请再次输入密码"));
} else if (value !== this.resetForm.newpwd) {
callback(new Error("两次输入密码不一致!"));
} else {
callback();
}
};
return {
resetForm: {
//传给后台所需要的参数
newpassword1: "",
password: "",
username: ""//此处只是后台需要的字段而已,如果前期有公用cookie里面有获取并且保存过,现在需要另外调用进来,具体的获取方法就看个人了
},
resetFormRules: {
password: [
{ required: true, message: "请输入旧密码", trigger: 'blur' }
],
newpwd: [
{ required: true, validator: validatePass, trigger: 'blur' }
],
newpassword1: [
{ required: true, validator: validatePass2, trigger: "blur" }
]
}
};
},
methods: {
toAmend() {
this.$refs.resetForm.validate(valid => {
if (valid) {
//这里的api.materialQuery.toAmend是调用前期我们统一的api接口url路径,不作参考 ,只要把后台需要的字段正常传进去即可
api.materialQuery.toAmend(this.resetForm)
.then(res => {
if(res.code === 2){
this.$message({
message: res.msg,
type: "error",
duration: "2000"
});
return false;
}
if (res.code === 0) {
this.$message.success("修改成功,3秒后跳转到登录页!");
setTimeout(() => {
this.logout();//调用跳转到登陆页的方法
}, 3000);
}
ic
})
.catch(() => {});
}
});
},
//这是修改成功后重新返回登陆页的方法,看个人需要自行调整
async logout() {
await this.$store.dispatch("user/logout");
this.$router.push(`/login`);
}
},
};
</script>
<style lang="scss" scoped>
.el-form {
width: 60%;
margin: 50px auto 0;
text-align: center;
button {
margin: 20px 0 0;
}
}
</style>
————————————————
版权声明:本文为CSDN博主「修炼中的小妖怪」的原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接及本声明。
原文链接:https://blog.csdn.net/weixin_42124196/article/details/101063455