期初数据前台
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

UserEdit.vue 2.7KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116
  1. <template>
  2. <div class="user-edit">
  3. <h1>编辑用户</h1>
  4. <form @submit.prevent="submitForm">
  5. <div class="form-group">
  6. <label for="username">用户名</label>
  7. <input type="text" id="username" v-model="userForm.username" required>
  8. </div>
  9. <div class="form-group">
  10. <label for="password">密码(不修改请留空)</label>
  11. <input type="password" id="password" v-model="userForm.password">
  12. </div>
  13. <div class="form-group">
  14. <label for="nickname">昵称</label>
  15. <input type="text" id="nickname" v-model="userForm.nickname" required>
  16. </div>
  17. <div class="form-group">
  18. <label for="email">邮箱</label>
  19. <input type="email" id="email" v-model="userForm.email">
  20. </div>
  21. <div class="form-group">
  22. <label for="phone">电话</label>
  23. <input type="text" id="phone" v-model="userForm.phone">
  24. </div>
  25. <div class="form-group">
  26. <label for="status">状态</label>
  27. <select id="status" v-model="userForm.status">
  28. <option value="1">启用</option>
  29. <option value="0">禁用</option>
  30. </select>
  31. </div>
  32. <div class="form-actions">
  33. <button type="submit">保存</button>
  34. <button type="button" @click="router.back()">取消</button>
  35. </div>
  36. </form>
  37. </div>
  38. </template>
  39. <script setup>
  40. import { reactive, onMounted } from 'vue'
  41. import { useRouter, useRoute } from 'vue-router'
  42. import { getUserById, updateUser } from '../api/userApi'
  43. const router = useRouter()
  44. const route = useRoute()
  45. const userForm = reactive({
  46. id: null,
  47. username: '',
  48. password: '',
  49. nickname: '',
  50. email: '',
  51. phone: '',
  52. status: 1
  53. })
  54. const loadUser = async () => {
  55. const id = route.params.id
  56. try {
  57. const response = await getUserById(id)
  58. const user = response.data
  59. Object.assign(userForm, user)
  60. } catch (error) {
  61. console.error('获取用户信息失败:', error)
  62. }
  63. }
  64. const submitForm = async () => {
  65. try {
  66. // 如果密码为空,不更新密码
  67. const updateData = { ...userForm }
  68. if (!updateData.password) {
  69. delete updateData.password
  70. }
  71. await updateUser(updateData)
  72. router.push('/users')
  73. } catch (error) {
  74. console.error('更新用户失败:', error)
  75. }
  76. }
  77. onMounted(() => {
  78. loadUser()
  79. })
  80. </script>
  81. <style scoped>
  82. .user-edit {
  83. padding: 2rem;
  84. max-width: 600px;
  85. margin: 0 auto;
  86. }
  87. .form-group {
  88. margin-bottom: 1rem;
  89. text-align: left;
  90. }
  91. label {
  92. display: block;
  93. margin-bottom: 0.5rem;
  94. }
  95. input, select {
  96. width: 100%;
  97. padding: 0.5rem;
  98. box-sizing: border-box;
  99. }
  100. .form-actions {
  101. margin-top: 2rem;
  102. display: flex;
  103. gap: 1rem;
  104. justify-content: center;
  105. }
  106. </style>