User.vue 6.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209
  1. <template>
  2. <div>
  3. <el-button type="primary" @click="openDialog()">新增用户</el-button>
  4. <el-button type="danger">清除用户身份票据</el-button>
  5. <el-table border :data="tableData" v-loading="loading" style="width: 100%">
  6. <el-table-column prop="Id" label="序号"></el-table-column>
  7. <el-table-column prop="LoginName" label="用户名"></el-table-column>
  8. <el-table-column prop="Password" label="密码"></el-table-column>
  9. <el-table-column prop="IsAction" label="是否启用">
  10. <template slot-scope="scope">{{ scope.row.IsAction ? '是':'否' }}</template>
  11. </el-table-column>
  12. <el-table-column prop="CreateTime" label="创建时间" :formatter="dateFormat"></el-table-column>
  13. <el-table-column label="操作">
  14. <template slot-scope="scope">
  15. <el-button
  16. type="primary"
  17. icon="el-icon-edit"
  18. @click="handleEdit(scope.$index, scope.row)"
  19. :disabled="scope.row.LoginName == 'admin'"
  20. ></el-button>
  21. <el-button
  22. type="danger"
  23. icon="el-icon-delete"
  24. @click="handleDelete(scope.$index, scope.row)"
  25. :disabled="scope.row.LoginName == 'admin'"
  26. ></el-button>
  27. </template>
  28. </el-table-column>
  29. </el-table>
  30. <el-dialog title="用户信息操作" :visible.sync="dialogFormVisible">
  31. <el-form :model="formData">
  32. <el-form-item label="登录名" :label-width="formLabelWidth">
  33. <el-input v-model="formData.LoginName" autocomplete="off"></el-input>
  34. </el-form-item>
  35. <el-form-item label="密码" :label-width="formLabelWidth">
  36. <el-input v-model="formData.Password" autocomplete="off"></el-input>
  37. </el-form-item>
  38. <el-form-item label="是否启用" :label-width="formLabelWidth">
  39. <el-radio v-model="formData.IsAction" :label="true" border>是</el-radio>
  40. <el-radio v-model="formData.IsAction" :label="false" border>否</el-radio>
  41. </el-form-item>
  42. </el-form>
  43. <div slot="footer" class="dialog-footer">
  44. <el-button @click="dialogFormVisible = false">取 消</el-button>
  45. <el-button type="primary" @click="handleCreateOrModify()">确 定</el-button>
  46. </div>
  47. </el-dialog>
  48. </div>
  49. </template>
  50. <script>
  51. export default {
  52. data() {
  53. return {
  54. loading: true,
  55. dialogFormVisible: false,
  56. formLabelWidth: "120px",
  57. tableData: [],
  58. formData: {
  59. Id: 0,
  60. LoginName: "",
  61. Password: "",
  62. IsAction: true,
  63. CreateTime: new Date()
  64. },
  65. options: {}
  66. };
  67. },
  68. mounted() {
  69. let token = "Browser " + sessionStorage.getItem("token");
  70. //window.console.log(token);
  71. this.options = {
  72. headers: {
  73. Authorization: token
  74. }
  75. };
  76. this.loadData();
  77. },
  78. methods: {
  79. loadData() {
  80. this.loading = true;
  81. this.$http
  82. .post("User/GetUserAll", null, this.options)
  83. .then(response => {
  84. window.console.log(response);
  85. this.tableData = response.data;
  86. this.loading = false;
  87. })
  88. .catch(e => {
  89. this.$message({
  90. message: "网络或程序异常!" + e,
  91. type: "error"
  92. });
  93. });
  94. },
  95. openDialog() {
  96. // 清除数据
  97. this.formData.Id = 0;
  98. this.formData.LoginName = "";
  99. this.formData.Password = "";
  100. this.formData.IsAction = true;
  101. this.formData.CreateTime = new Date();
  102. this.dialogFormVisible = true;
  103. },
  104. // 新增
  105. handleCreateOrModify() {
  106. window.console.log(this.formData);
  107. //window.console.log(JSON.stringify(this.formData));
  108. if (!this.formData.Id) {
  109. // ID 无效时 视为新增
  110. this.loading = true;
  111. this.$http
  112. .post("User/CreateUser", this.formData, this.options)
  113. .then(response => {
  114. this.loading = false;
  115. window.console.log(response);
  116. this.$message({
  117. message: "创建成功!",
  118. type: "success"
  119. });
  120. this.dialogFormVisible = false;
  121. this.loadData();
  122. })
  123. .catch(e => {
  124. this.$message({
  125. message: "网络或程序异常!" + e,
  126. type: "error"
  127. });
  128. });
  129. } else {
  130. this.loading = true;
  131. this.$http
  132. .post("User/ModifiedUser", this.formData, this.options)
  133. .then(response => {
  134. this.loading = false;
  135. window.console.log(response);
  136. this.$message({
  137. message: "修改成功!",
  138. type: "success"
  139. });
  140. this.dialogFormVisible = false;
  141. this.loadData();
  142. })
  143. .catch(e => {
  144. this.$message({
  145. message: "网络或程序异常!" + e,
  146. type: "error"
  147. });
  148. });
  149. }
  150. },
  151. handleEdit(index, row) {
  152. window.console.log(index, row);
  153. this.formData = row;
  154. this.dialogFormVisible = true;
  155. },
  156. handleDelete(index, row) {
  157. window.console.log(index, row);
  158. this.$confirm("此操作将永久此条数据, 是否继续?", "提示", {
  159. confirmButtonText: "确定",
  160. cancelButtonText: "取消",
  161. type: "warning"
  162. })
  163. .then(() => {
  164. // 已确认删除
  165. // 调接口删除
  166. this.loading = true;
  167. this.$http
  168. .post(`User/DeleteUser?id=${row.Id}`, null, this.options)
  169. .then(response => {
  170. this.loading = false;
  171. window.console.log(response);
  172. this.$message({
  173. message: "删除成功!",
  174. type: "success"
  175. });
  176. this.loadData();
  177. })
  178. .catch(e => {
  179. this.$message({
  180. message: "网络或程序异常!" + e,
  181. type: "error"
  182. });
  183. });
  184. })
  185. .catch(() => {
  186. this.$message({
  187. type: "info",
  188. message: "已取消删除"
  189. });
  190. });
  191. },
  192. //时间格式化
  193. dateFormat: function(row) {
  194. //row 表示一行数据, CreateTime 表示要格式化的字段名称
  195. let t = new Date(row.CreateTime);
  196. return t.getFullYear() + "-" + (t.getMonth() + 1) + "-" + t.getDate();
  197. }
  198. }
  199. };
  200. </script>
  201. <style scoped>
  202. .el-table {
  203. margin-top: 20px;
  204. }
  205. </style>