update.html 13 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260
  1. <!DOCTYPE html>
  2. <html lang="zh-cn">
  3. <head>
  4. <meta charset="UTF-8">
  5. <title>更新页面</title>
  6. <link rel="stylesheet" href="/app/admin/component/pear/css/pear.css" />
  7. <link rel="stylesheet" href="/app/admin/component/jsoneditor/css/jsoneditor.css" />
  8. <link rel="stylesheet" href="/app/admin/admin/css/reset.css" />
  9. </head>
  10. <body>
  11. <form class="layui-form">
  12. <div class="mainBox">
  13. <div class="main-container mr-5">
  14. <div class="layui-form-item">
  15. <label class="layui-form-label required">标题</label>
  16. <div class="layui-input-block">
  17. <input type="text" name="name" value="" required lay-verify="required" class="layui-input">
  18. </div>
  19. </div>
  20. <div class="layui-form-item">
  21. <label class="layui-form-label required">封面图</label>
  22. <div class="layui-input-block">
  23. <img class="img-3" src=""/>
  24. <input type="text" style="display:none" name="img" value="" />
  25. <button type="button" class="pear-btn pear-btn-primary pear-btn-sm" id="img" permission="app.admin.upload.image">
  26. <i class="layui-icon layui-icon-upload"></i>上传图片
  27. </button>
  28. <button type="button" class="pear-btn pear-btn-primary pear-btn-sm" id="attachment-choose-img" permission="app.admin.upload.attachment">
  29. <i class="layui-icon layui-icon-align-left"></i>选择图片
  30. </button>
  31. </div>
  32. </div>
  33. <div class="layui-form-item">
  34. <label class="layui-form-label">状态</label>
  35. <div class="layui-input-block">
  36. <input type="checkbox" id="state" lay-filter="state" lay-skin="switch" />
  37. <input type="text" style="display:none" name="state" value="0" />
  38. </div>
  39. </div>
  40. <div class="layui-form-item">
  41. <label class="layui-form-label">推荐</label>
  42. <div class="layui-input-block">
  43. <input type="checkbox" id="is_recommend" lay-filter="is_recommend" lay-skin="switch" />
  44. <input type="text" style="display:none" name="is_recommend" value="0" />
  45. </div>
  46. </div>
  47. <div class="layui-form-item">
  48. <label class="layui-form-label">文章类型</label>
  49. <div class="layui-input-block">
  50. <div name="article_type_id" id="article_type_id" value="" ></div>
  51. </div>
  52. </div>
  53. <div class="layui-form-item">
  54. <label class="layui-form-label required">描述</label>
  55. <div class="layui-input-block">
  56. <textarea name="describe" required lay-verify="required" class="layui-textarea"></textarea>
  57. </div>
  58. </div>
  59. <div class="layui-form-item">
  60. <label class="layui-form-label required">详情</label>
  61. <div class="layui-input-block">
  62. <textarea id="txt" name="txt" required lay-verify="required" class="layui-textarea"></textarea>
  63. </div>
  64. </div>
  65. </div>
  66. </div>
  67. <div class="bottom">
  68. <div class="button-container">
  69. <button type="submit" class="pear-btn pear-btn-primary pear-btn-md" lay-submit="" lay-filter="save">
  70. 提交
  71. </button>
  72. <button type="reset" class="pear-btn pear-btn-md">
  73. 重置
  74. </button>
  75. </div>
  76. </div>
  77. </form>
  78. <script src="/app/admin/component/layui/layui.js?v=2.8.12"></script>
  79. <script src="/app/admin/component/pear/pear.js"></script>
  80. <script src="/app/admin/component/jsoneditor/jsoneditor.js"></script>
  81. <script src="/app/admin/admin/js/permission.js"></script>
  82. <script>
  83. // 相关接口
  84. const PRIMARY_KEY = "id";
  85. const SELECT_API = "/app/admin/article/select" + location.search;
  86. const UPDATE_API = "/app/admin/article/update";
  87. // 获取数据库记录
  88. layui.use(["form", "util", "popup"], function () {
  89. let $ = layui.$;
  90. $.ajax({
  91. url: SELECT_API,
  92. dataType: "json",
  93. success: function (res) {
  94. // 给表单初始化数据
  95. layui.each(res.data[0], function (key, value) {
  96. let obj = $('*[name="'+key+'"]');
  97. if (key === "password") {
  98. obj.attr("placeholder", "不更新密码请留空");
  99. return;
  100. }
  101. if (typeof obj[0] === "undefined" || !obj[0].nodeName) return;
  102. if (obj[0].nodeName.toLowerCase() === "textarea") {
  103. obj.val(value);
  104. } else {
  105. obj.attr("value", value);
  106. obj[0].value = value;
  107. }
  108. });
  109. // 字段 封面图 img
  110. layui.use(["upload", "layer"], function() {
  111. let input = layui.$("#img").prev();
  112. input.prev().attr("src", input.val());
  113. layui.$("#attachment-choose-img").on("click", function() {
  114. parent.layer.open({
  115. type: 2,
  116. title: "选择附件",
  117. content: "/app/admin/upload/attachment?ext=jpg,jpeg,png,gif,bmp",
  118. area: ["95%", "90%"],
  119. success: function (layero, index) {
  120. parent.layui.$("#layui-layer" + index).data("callback", function (data) {
  121. input.val(data.url).prev().attr("src", data.url);
  122. });
  123. }
  124. });
  125. });
  126. layui.upload.render({
  127. elem: "#img",
  128. acceptMime: "image/gif,image/jpeg,image/jpg,image/png",
  129. url: "/app/admin/upload/image",
  130. field: "__file__",
  131. done: function (res) {
  132. if (res.code > 0) return layui.layer.msg(res.msg);
  133. this.item.prev().val(res.data.url).prev().attr("src", res.data.url);
  134. }
  135. });
  136. });
  137. // 字段 详情 txt
  138. layui.use(["tinymce"], function() {
  139. var tinymce = layui.tinymce
  140. var edit = tinymce.render({
  141. elem: "#txt",
  142. height: 400,
  143. 'lay-verify': "required",
  144. 'images_upload_url': "/app/admin/upload/imagetxt",
  145. });
  146. edit.on("blur", function(){
  147. layui.$("#txt").val(edit.getContent());
  148. });
  149. });
  150. // 字段 状态 state
  151. layui.use(["form"], function() {
  152. layui.$("#state").attr("checked", layui.$('input[name="state"]').val() != 0);
  153. layui.form.render();
  154. layui.form.on("switch(state)", function(data) {
  155. layui.$('input[name="state"]').val(this.checked ? 1 : 0);
  156. });
  157. })
  158. // 字段 推荐 is_recommend
  159. layui.use(["form"], function() {
  160. layui.$("#is_recommend").attr("checked", layui.$('input[name="is_recommend"]').val() != 0);
  161. layui.form.render();
  162. layui.form.on("switch(is_recommend)", function(data) {
  163. layui.$('input[name="is_recommend"]').val(this.checked ? 1 : 0);
  164. });
  165. })
  166. // 字段 文章类型 article_type_id
  167. layui.use(["jquery", "xmSelect", "popup"], function() {
  168. layui.$.ajax({
  169. url: "/app/admin/article-type/addselect",
  170. dataType: "json",
  171. success: function (res) {
  172. let value = layui.$("#article_type_id").attr("value");
  173. let initValue = value ? value.split(",") : [];
  174. layui.xmSelect.render({
  175. el: "#article_type_id",
  176. name: "article_type_id",
  177. initValue: initValue,
  178. filterable: true,
  179. data: res.data,
  180. model: {"icon":"hidden","label":{"type":"text"}},
  181. clickClose: true,
  182. radio: true,
  183. });
  184. if (res.code) {
  185. layui.popup.failure(res.msg);
  186. }
  187. }
  188. });
  189. });
  190. // ajax返回失败
  191. if (res.code) {
  192. layui.popup.failure(res.msg);
  193. }
  194. }
  195. });
  196. });
  197. //提交事件
  198. layui.use(["form", "popup"], function () {
  199. // 字段验证允许为空
  200. layui.form.verify({
  201. phone: [/(^$)|^1\d{10}$/, "请输入正确的手机号"],
  202. email: [/(^$)|^([a-zA-Z0-9_\.\-])+\@(([a-zA-Z0-9\-])+\.)+([a-zA-Z0-9]{2,4})+$/, "邮箱格式不正确"],
  203. url: [/(^$)|(^#)|(^http(s*):\/\/[^\s]+\.[^\s]+)/, "链接格式不正确"],
  204. number: [/(^$)|^\d+$/,'只能填写数字'],
  205. date: [/(^$)|^(\d{4})[-\/](\d{1}|0\d{1}|1[0-2])([-\/](\d{1}|0\d{1}|[1-2][0-9]|3[0-1]))*$/, "日期格式不正确"],
  206. identity: [/(^$)|(^\d{15}$)|(^\d{17}(x|X|\d)$)/, "请输入正确的身份证号"]
  207. });
  208. layui.form.on("submit(save)", function (data) {
  209. data.field[PRIMARY_KEY] = layui.url().search[PRIMARY_KEY];
  210. layui.$.ajax({
  211. url: UPDATE_API,
  212. type: "POST",
  213. dateType: "json",
  214. data: data.field,
  215. success: function (res) {
  216. if (res.code) {
  217. return layui.popup.failure(res.msg);
  218. }
  219. return layui.popup.success("操作成功", function () {
  220. parent.refreshTable();
  221. parent.layer.close(parent.layer.getFrameIndex(window.name));
  222. });
  223. }
  224. });
  225. return false;
  226. });
  227. });
  228. </script>
  229. </body>
  230. </html>