password.vue 2.38 KB
Newer Older
renhanxue's avatar
renhanxue committed
1
<template>
renhanxue's avatar
renhanxue committed
2
  <div>
renhanxue's avatar
renhanxue committed
3
    <div class="title">修改密码</div>
renhanxue's avatar
renhanxue committed
4
    <el-form ref="form" :model="form" label-width="100px" :rules="rules">
5
      <el-form-item label="用户名:" prop="userName">
dupengyu's avatar
dupengyu committed
6
        <el-input v-model="form.userName" disabled />
renhanxue's avatar
renhanxue committed
7
      </el-form-item>
yanzhongrong's avatar
yanzhongrong committed
8
      <el-form-item label="原密码:" prop="originPwd">
9
        <el-input type="password" v-model="form.originPwd" />
renhanxue's avatar
renhanxue committed
10
      </el-form-item>
yanzhongrong's avatar
yanzhongrong committed
11
      <el-form-item label="新密码:" prop="password">
12
        <el-input type="password" v-model="form.password" />
renhanxue's avatar
renhanxue committed
13
      </el-form-item>
yanzhongrong's avatar
yanzhongrong committed
14
      <el-form-item label="确认新密码:" prop="sureNewPwd">
15
        <el-input type="password" v-model="form.sureNewPwd" />
renhanxue's avatar
renhanxue committed
16 17 18 19 20 21
      </el-form-item>
    </el-form>
    <div class="btn">
      <el-button type="primary" @click="confirm">确认修改</el-button>
    </div>
  </div>
renhanxue's avatar
renhanxue committed
22 23 24
</template>

<script>
yanzhongrong's avatar
yanzhongrong committed
25
import { updatePwd } from '../../api';
renhanxue's avatar
renhanxue committed
26 27
export default {
  data() {
renhanxue's avatar
renhanxue committed
28 29
    var validatePass2 = (rule, value, callback) => {
      if (value === '') {
yanzhongrong's avatar
yanzhongrong committed
30
        callback(new Error('请再次输入新密码'));
31
      } else if (value !== this.form.password) {
yanzhongrong's avatar
yanzhongrong committed
32
        callback(new Error('两次输入密码不一致!'));
renhanxue's avatar
renhanxue committed
33
      } else {
yanzhongrong's avatar
yanzhongrong committed
34
        callback();
renhanxue's avatar
renhanxue committed
35 36
      }
    }
37
    let { userId, userName } = this.$store.state.user.userBaseInfo
renhanxue's avatar
renhanxue committed
38
    return {
renhanxue's avatar
renhanxue committed
39
      form: {
40
        userName: userName,
yanzhongrong's avatar
yanzhongrong committed
41 42 43
        originPwd: '',
        password: '',
        sureNewPwd: '',
44
        userId: userId
renhanxue's avatar
renhanxue committed
45 46
      },
      rules: {
47 48 49 50
        userName: { required: true, message: '请输入用户名', trigger: 'blur' },
        originPwd: { required: true, message: '请输入原密码', trigger: 'blur' },
        password: { required: true, message: '请输入新密码', trigger: 'blur' },
        sureNewPwd: [{ required: true, validator: validatePass2, trigger: 'blur' }]
renhanxue's avatar
renhanxue committed
51
      }
renhanxue's avatar
renhanxue committed
52 53
    }
  },
renhanxue's avatar
renhanxue committed
54 55 56 57
  methods: {
    confirm() {
      this.$refs.form.validate((valid) => {
        if (valid) {
yanzhongrong's avatar
yanzhongrong committed
58
          updatePwd(this.form).then(res => {
yanzhongrong's avatar
yanzhongrong committed
59
            this.$message.success('操作成功');
yanzhongrong's avatar
yanzhongrong committed
60
          })
renhanxue's avatar
renhanxue committed
61
        } else {
yanzhongrong's avatar
yanzhongrong committed
62
          return false;
renhanxue's avatar
renhanxue committed
63 64 65 66
        }
      })
    }
  }
renhanxue's avatar
renhanxue committed
67 68 69
}
</script>
<style lang="scss" scoped>
renhanxue's avatar
renhanxue committed
70 71 72 73
.btn {
  margin-top: 50px;
  text-align: center;
}
renhanxue's avatar
renhanxue committed
74 75 76 77 78 79 80 81 82 83 84 85 86 87 88
.el-form {
  width: 500px;
  margin: 0 auto;
}
.title {
  width: 100%;
  height: 60px;
  background: rgba(226, 235, 255, 0.39);
  line-height: 60px;
  font-size: 18px;
  color: #333;
  font-weight: 500;
  text-align: center;
  margin-bottom: 30px;
}
renhanxue's avatar
renhanxue committed
89
</style>