Password.vue 2.4 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283
  1. <template>
  2. <el-form ref="passwordForm" :model="user" :rules="rules">
  3. <el-form-item label="旧密码:" prop="oldPassword">
  4. <el-input v-model.trim="user.oldPassword" />
  5. </el-form-item>
  6. <el-form-item label="新密码:" prop="password">
  7. <el-input v-model.trim="user.password" />
  8. </el-form-item>
  9. <el-form-item label="确认新密码:" prop="confirmPassword">
  10. <el-input v-model.trim="user.confirmPassword" />
  11. </el-form-item>
  12. <el-form-item>
  13. <el-button type="primary" @click="onSubmit('passwordForm')">保存修改</el-button>
  14. </el-form-item>
  15. </el-form>
  16. </template>
  17. <script>
  18. import { updatePassword } from '@/api/sys/user'
  19. export default {
  20. props: {
  21. user: {
  22. type: Object,
  23. default: () => {
  24. return {
  25. userId: 0,
  26. oldPassword: '',
  27. password: '',
  28. confirmPassword: ''
  29. }
  30. }
  31. },
  32. rules: {
  33. type: Object,
  34. default: () => {
  35. return {
  36. oldPassword: [
  37. { required: true, message: '请输入旧密码', trigger: 'blur' },
  38. { min: 6, max: 30, message: '长度在 6 到 30 个字符', trigger: 'blur' }
  39. ],
  40. password: [
  41. { required: true, message: '请输入新密码', trigger: 'blur' },
  42. { min: 6, max: 30, message: '长度在 6 到 30 个字符', trigger: 'blur' }
  43. ],
  44. confirmPassword: [
  45. { required: true, message: '请确认新密码', trigger: 'blur' },
  46. { min: 6, max: 30, message: '长度在 6 到 30 个字符', trigger: 'blur' }
  47. ]
  48. }
  49. }
  50. }
  51. },
  52. methods: {
  53. onSubmit(formName) {
  54. this.$refs[formName].validate(valid => {
  55. if (valid) {
  56. this.$confirm('是否提交数据', '提示', {
  57. confirmButtonText: '确定',
  58. cancelButtonText: '取消',
  59. type: 'warning'
  60. }).then(() => {
  61. updatePassword(this.user).then(response => {
  62. this.$message({
  63. message: '修改成功',
  64. type: 'success',
  65. duration: 1000
  66. })
  67. this.$router.back()
  68. })
  69. })
  70. } else {
  71. this.$message({
  72. message: '验证失败',
  73. type: 'error',
  74. duration: 1000
  75. })
  76. return false
  77. }
  78. })
  79. }
  80. }
  81. }
  82. </script>