Person.vue 5.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164
  1. <template>
  2. <div class="main-content">
  3. <el-card style="width: 50%; margin: 30px auto">
  4. <div style="text-align: right; margin-bottom: 20px">
  5. <el-button type="primary" @click="updatePassword">修改密码</el-button>
  6. </div>
  7. <el-form :model="user" label-width="80px" style="padding-right: 20px">
  8. <div style="margin: 15px; text-align: center">
  9. <el-upload
  10. class="avatar-uploader"
  11. :action="$baseUrl + '/files/upload'"
  12. :show-file-list="false"
  13. :on-success="handleAvatarSuccess"
  14. >
  15. <img v-if="user.avatar" :src="user.avatar" class="avatar" />
  16. <i v-else class="el-icon-plus avatar-uploader-icon"></i>
  17. </el-upload>
  18. </div>
  19. <el-form-item label="用户名" prop="username">
  20. <el-input v-model="user.username" placeholder="用户名" disabled></el-input>
  21. </el-form-item>
  22. <el-form-item label="姓名" prop="name">
  23. <el-input v-model="user.name" placeholder="姓名"></el-input>
  24. </el-form-item>
  25. <el-form-item label="电话" prop="phone">
  26. <el-input v-model="user.phone" placeholder="电话"></el-input>
  27. </el-form-item>
  28. <el-form-item label="邮箱" prop="email">
  29. <el-input v-model="user.email" placeholder="邮箱"></el-input>
  30. </el-form-item>
  31. <div style="text-align: center; margin-bottom: 20px">
  32. <el-button type="primary" @click="update">保 存</el-button>
  33. </div>
  34. </el-form>
  35. </el-card>
  36. <el-dialog title="修改密码" :visible.sync="dialogVisible" width="30%" :close-on-click-modal="false" destroy-on-close>
  37. <el-form :model="user" label-width="80px" style="padding-right: 20px" :rules="rules" ref="formRef">
  38. <el-form-item label="原始密码" prop="password">
  39. <el-input show-password v-model="user.password" placeholder="原始密码"></el-input>
  40. </el-form-item>
  41. <el-form-item label="新密码" prop="newPassword">
  42. <el-input show-password v-model="user.newPassword" placeholder="新密码"></el-input>
  43. </el-form-item>
  44. <el-form-item label="确认密码" prop="confirmPassword">
  45. <el-input show-password v-model="user.confirmPassword" placeholder="确认密码"></el-input>
  46. </el-form-item>
  47. </el-form>
  48. <div slot="footer" class="dialog-footer">
  49. <el-button @click="fromVisible = false">取 消</el-button>
  50. <el-button type="primary" @click="save">确 定</el-button>
  51. </div>
  52. </el-dialog>
  53. </div>
  54. </template>
  55. <script>
  56. export default {
  57. data() {
  58. const validatePassword = (rule, value, callback) => {
  59. if (value === '') {
  60. callback(new Error('请确认密码'))
  61. } else if (value !== this.user.newPassword) {
  62. callback(new Error('确认密码错误'))
  63. } else {
  64. callback()
  65. }
  66. }
  67. return {
  68. user: JSON.parse(localStorage.getItem('xm-user') || '{}'),
  69. dialogVisible: false,
  70. rules: {
  71. password: [
  72. { required: true, message: '请输入原始密码', trigger: 'blur' },
  73. ],
  74. newPassword: [
  75. { required: true, message: '请输入新密码', trigger: 'blur' },
  76. ],
  77. confirmPassword: [
  78. { validator: validatePassword, required: true, trigger: 'blur' },
  79. ],
  80. }
  81. }
  82. },
  83. created() {
  84. },
  85. methods: {
  86. update() {
  87. // 保存当前的用户信息到数据库
  88. this.$request.put('/admin/update', this.user).then(res => {
  89. if (res.code === '200') {
  90. // 成功更新
  91. this.$message.success('保存成功')
  92. // 更新浏览器缓存里的用户信息
  93. localStorage.setItem('xm-user', JSON.stringify(this.user))
  94. // 触发父级的数据更新
  95. this.$emit('update:user')
  96. } else {
  97. this.$message.error(res.msg)
  98. }
  99. })
  100. },
  101. handleAvatarSuccess(response, file, fileList) {
  102. // 把user的头像属性换成上传的图片的链接
  103. this.$set(this.user, 'avatar', response.data)
  104. },
  105. // 修改密码
  106. updatePassword() {
  107. this.dialogVisible = true
  108. },
  109. save() {
  110. this.$refs.formRef.validate((valid) => {
  111. if (valid) {
  112. this.$request.put('/updatePassword', this.user).then(res => {
  113. if (res.code === '200') {
  114. // 成功更新
  115. this.$message.success('修改密码成功')
  116. this.$router.push('/login')
  117. } else {
  118. this.$message.error(res.msg)
  119. }
  120. })
  121. }
  122. })
  123. }
  124. }
  125. }
  126. </script>
  127. <style scoped>
  128. /deep/.el-form-item__label {
  129. font-weight: bold;
  130. }
  131. /deep/.el-upload {
  132. border-radius: 50%;
  133. }
  134. /deep/.avatar-uploader .el-upload {
  135. border: 1px dashed #d9d9d9;
  136. cursor: pointer;
  137. position: relative;
  138. overflow: hidden;
  139. border-radius: 50%;
  140. }
  141. /deep/.avatar-uploader .el-upload:hover {
  142. border-color: #409EFF;
  143. }
  144. .avatar-uploader-icon {
  145. font-size: 28px;
  146. color: #8c939d;
  147. width: 120px;
  148. height: 120px;
  149. line-height: 120px;
  150. text-align: center;
  151. border-radius: 50%;
  152. }
  153. .avatar {
  154. width: 120px;
  155. height: 120px;
  156. display: block;
  157. border-radius: 50%;
  158. }
  159. </style>