user.html 6.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194
  1. <!DOCTYPE html>
  2. <html>
  3. <head>
  4. <meta charset="UTF-8">
  5. <title>管理员页面</title>
  6. <script src="https://cdnjs.cloudflare.com/ajax/libs/vue/2.5.16/vue.min.js"></script>
  7. <script src="https://cdnjs.cloudflare.com/ajax/libs/axios/0.18.0/axios.min.js"></script>
  8. <script src="https://cdn.bootcdn.net/ajax/libs/lodash.js/4.17.21/lodash.min.js"></script>
  9. <script src="js/login.js"></script>
  10. </head>
  11. <body>
  12. <div id="app">
  13. <div>
  14. <h2>用户列表</h2>
  15. <table>
  16. <thead>
  17. <tr>
  18. <th>ID</th>
  19. <th>姓名</th>
  20. <th>备注</th>
  21. <th>操作</th>
  22. </tr>
  23. </thead>
  24. <tbody>
  25. <tr v-for="user in userList" :key="user.id">
  26. <td>{{ user.id }}</td>
  27. <td>{{ user.name }}</td>
  28. <td>{{ user.introduction }}</td>
  29. <td>
  30. <button @click="editUser(user)">编辑</button>
  31. <button @click="deleteUser(user)">删除</button>
  32. </td>
  33. </tr>
  34. </tbody>
  35. </table>
  36. <br>
  37. <button @click="addUser">新增用户</button>
  38. </div>
  39. <div v-if="showAddUser">
  40. <h2>新增用户</h2>
  41. <form @submit.prevent="submitAddUser">
  42. <label for="name">姓名:</label>
  43. <input type="text" id="name" v-model="newUser.name" required>
  44. <br>
  45. <label for="introduction">备注:</label>
  46. <input type="text" id="introduction" v-model="newUser.introduction" required>
  47. <br>
  48. <label for="password">密码:</label>
  49. <input type="password" id="password" v-model="newUser.password" required>
  50. <br>
  51. <button type="submit">提交</button>
  52. </form>
  53. </div>
  54. <div v-if="showEditUser">
  55. <h2>编辑用户</h2>
  56. <form @submit.prevent="submitEditUser">
  57. <label for="name">姓名:</label>
  58. <input type="text" id="name" v-model="selectedUser.name" required>
  59. <br>
  60. <label for="introduction">备注:</label>
  61. <input type="text" id="introduction" v-model="selectedUser.introduction" required>
  62. <br>
  63. <label for="password">密码:</label>
  64. <input type="password" id="password" v-model="selectedUser.password" required>
  65. <br>
  66. <button type="submit">提交</button>
  67. </form>
  68. </div>
  69. </div>
  70. <script>
  71. var app = new Vue({
  72. el: '#app',
  73. data: {
  74. username: '',
  75. password: '',
  76. isLoggedIn: false,
  77. userList: [],
  78. showAddUser: false,
  79. showEditUser: false,
  80. newUser: {
  81. name: '',
  82. introduction: '',
  83. password: ''
  84. },
  85. selectedUser: {
  86. id: '',
  87. name: '',
  88. introduction: '',
  89. password: ''
  90. }
  91. },
  92. methods: {
  93. getUserList: function() {
  94. axios.get('https://api.tianyunperfect.cn/user/user_list', {
  95. headers: {
  96. 'Authorization': 'Bearer ' + localStorage.getItem('token')
  97. }
  98. })
  99. .then(response => {
  100. if (response.data.code === 1) {
  101. this.userList = response.data.data;
  102. } else {
  103. alert(response.data.message);
  104. }
  105. })
  106. .catch(error => {
  107. alert(error);
  108. });
  109. },
  110. addUser: function() {
  111. this.showAddUser = true;
  112. },
  113. submitAddUser: function() {
  114. axios.post('https://api.tianyunperfect.cn/user/register', {
  115. name: this.newUser.name,
  116. introduction: this.newUser.introduction,
  117. password: this.newUser.password
  118. }, {
  119. headers: {
  120. 'Authorization': 'Bearer ' + localStorage.getItem('token')
  121. }
  122. })
  123. .then(response => {
  124. if (response.data.code === 1) {
  125. this.showAddUser = false;
  126. this.getUserList();
  127. } else {
  128. alert(response.data.message);
  129. }
  130. })
  131. .catch(error => {
  132. alert(error);
  133. });
  134. },
  135. editUser: function(user) {
  136. this.showEditUser = true;
  137. this.selectedUser.id = user.id;
  138. this.selectedUser.name = user.name;
  139. this.selectedUser.introduction = user.introduction;
  140. this.selectedUser.password = '';
  141. },
  142. submitEditUser: function() {
  143. axios.post('https://api.tianyunperfect.cn/user/update_password', {
  144. id: this.selectedUser.id,
  145. password: this.selectedUser.password
  146. }, {
  147. headers: {
  148. 'Authorization': 'Bearer ' + localStorage.getItem('token')
  149. }
  150. })
  151. .then(response => {
  152. if (response.data.code === 1) {
  153. this.showEditUser = false;
  154. this.getUserList();
  155. } else {
  156. alert(response.data.message);
  157. }
  158. })
  159. .catch(error => {
  160. alert(error);
  161. });
  162. },
  163. deleteUser: function(user) {
  164. if (confirm('确定删除该用户?')) {
  165. axios.post('https://api.tianyunperfect.cn/user/delete', {
  166. id: user.id
  167. }, {
  168. headers: {
  169. 'Authorization': 'Bearer ' + localStorage.getItem('token')
  170. }
  171. })
  172. .then(response => {
  173. if (response.data.code === 1) {
  174. this.getUserList();
  175. } else {
  176. alert(response.data.message);
  177. }
  178. })
  179. .catch(error => {
  180. alert(error);
  181. });
  182. }
  183. }
  184. },
  185. created: function() {
  186. if (checkLogin()) {
  187. this.isLoggedIn = true;
  188. this.getUserList();
  189. }
  190. }
  191. });
  192. </script>
  193. </body>
  194. </html>