major.js 3.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150
  1. $(function() {
  2. var defaultPage = 0;
  3. var defaultSize = 10;
  4. var currentPage = defaultPage;
  5. var currentSize = defaultSize;
  6. var tableFirstLoad = true;
  7. layui.use(["form", "table", "laypage", "layer"], function() {
  8. var table = layui.table;
  9. var laypage = layui.laypage;
  10. var layer = layui.layer;
  11. function loadMajorList(page, size) {
  12. if (page === null || page === undefined) page = defaultPage;
  13. if (size === null || size === undefined) size = defaultSize;
  14. var tableOption = {
  15. elem: "#majorList",
  16. height: "full-81",
  17. limit: size,
  18. cols: [
  19. [{
  20. type: "checkbox"
  21. },
  22. // {
  23. // field: "id",
  24. // title: "序号",
  25. // align: "center"
  26. // },
  27. {
  28. field: "major",
  29. title: "专业名",
  30. align: "center"
  31. },
  32. {
  33. field: "mark",
  34. title: "备注",
  35. align: "center"
  36. },
  37. {
  38. fixed: "right",
  39. title: "操作",
  40. toolbar: "#operationToolbar",
  41. width: 330,
  42. align: "center"
  43. }
  44. ]
  45. ]
  46. };
  47. var url = "api/major/listAll?page=" + (page + 1) + "&size=" + size;
  48. fetchJSON(url, {}, "get", function(data) {
  49. if (data.status === 0) {
  50. if (tableFirstLoad) {
  51. tableFirstLoad = false;
  52. laypage.render({
  53. curr: page + 1,
  54. elem: "pagination",
  55. count: data.data.total,
  56. layout: ["count", "prev", "page", "next", "limit", "refresh", "skip"],
  57. jump: function(obj, first) {
  58. if (first) return;
  59. currentPage = obj.curr - 1;
  60. currentSize = obj.limit;
  61. loadMajorList(currentPage, currentSize);
  62. }
  63. });
  64. }
  65. tableOption.data = data.data;
  66. table.render(tableOption);
  67. } else {
  68. showMsg(data.msg, 2, 2000);
  69. }
  70. });
  71. }
  72. loadMajorList();
  73. // 监听表内工具条
  74. table.on("tool(majorList)", function(obj) {
  75. var data = obj.data;
  76. if (obj.event === "edit") {
  77. // 打开编辑框 进行详细编辑
  78. x_admin_show(
  79. "编辑",
  80. encodeURI(
  81. "../admin/major-edit.html?id=" + data.id + "&major=" + data.major + "&mark=" + data.mark
  82. ),
  83. 470,
  84. 260,
  85. function() {
  86. loadMajorList(currentPage, currentSize);
  87. }
  88. );
  89. } else if (obj.event === "delete") {
  90. // 删除
  91. var ids = [];
  92. ids.push(data.id);
  93. layer.confirm("确认要删除吗?", function() {
  94. fetchJSON("api/major/delete", {
  95. ids: ids
  96. }, "post", function(data) {
  97. if (data.status === 0) {
  98. showMsg("已删除!", 1, 2000);
  99. tableFirstLoad = true;
  100. loadMajorList(currentPage, currentSize);
  101. } else {
  102. showMsg(data.msg, 2, 2000);
  103. }
  104. });
  105. });
  106. }
  107. });
  108. // 批量删除
  109. $("#batchDelete").on("click", function(e) {
  110. e.preventDefault();
  111. var checkedData = table.checkStatus("majorList").data;
  112. if (checkedData.length === 0) {
  113. showMsg("未选择需要删除的日志", 2, 2000);
  114. return;
  115. }
  116. layer.confirm("确认要删除吗?", function() {
  117. var ids = [];
  118. for (var i = 0; i < checkedData.length; i++) {
  119. ids.push(checkedData[i].id);
  120. }
  121. fetchJSON("api/major/delete", {
  122. ids: ids
  123. }, "post", function(data) {
  124. if (data.status === 0) {
  125. showMsg("已删除!");
  126. tableFirstLoad = true;
  127. loadMajorList(currentPage, currentSize);
  128. } else {
  129. showMsg(data.msg, 2, 2000);
  130. }
  131. });
  132. });
  133. });
  134. // 新建用户
  135. $("#addmajor").on("click", function(e) {
  136. e.preventDefault();
  137. tableFirstLoad = true;
  138. x_admin_show("增加", "../admin/major-edit.html?id=0&mark=&major=", 470, 260, function() {
  139. loadMajorList(currentPage, currentSize);
  140. });
  141. });
  142. });
  143. });