Course.vue 5.7 KB

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