update.html 9.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211
  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">支付名称</label>
  16. <div class="layui-input-block">
  17. <input type="text" name="name" value="" class="layui-input">
  18. </div>
  19. </div>
  20. <div class="layui-form-item">
  21. <label class="layui-form-label">渠道名称</label>
  22. <div class="layui-input-block">
  23. <input type="text" name="title" value="" class="layui-input">
  24. </div>
  25. </div>
  26. <div class="layui-form-item">
  27. <label class="layui-form-label">渠道类型</label>
  28. <div class="layui-input-block">
  29. <input type="number" name="type" value="" class="layui-input">
  30. </div>
  31. </div>
  32. <div class="layui-form-item">
  33. <label class="layui-form-label">支付标识</label>
  34. <div class="layui-input-block">
  35. <input type="text" name="characteristic" value="" class="layui-input">
  36. </div>
  37. </div>
  38. <div class="layui-form-item">
  39. <label class="layui-form-label">排序</label>
  40. <div class="layui-input-block">
  41. <input type="number" name="sort" value="" class="layui-input">
  42. </div>
  43. </div>
  44. <div class="layui-form-item">
  45. <label class="layui-form-label">状态</label>
  46. <div class="layui-input-block">
  47. <input type="checkbox" id="state" lay-filter="state" lay-skin="switch" />
  48. <input type="text" style="display:none" name="state" value="0" />
  49. </div>
  50. </div>
  51. <div class="layui-form-item">
  52. <label class="layui-form-label">图片</label>
  53. <div class="layui-input-block">
  54. <img class="img-3" src=""/>
  55. <input type="text" style="display:none" name="img" value="" />
  56. <button type="button" class="pear-btn pear-btn-primary pear-btn-sm" id="img" permission="app.admin.upload.image">
  57. <i class="layui-icon layui-icon-upload"></i>上传图片
  58. </button>
  59. <button type="button" class="pear-btn pear-btn-primary pear-btn-sm" id="attachment-choose-img" permission="app.admin.upload.attachment">
  60. <i class="layui-icon layui-icon-align-left"></i>选择图片
  61. </button>
  62. </div>
  63. </div>
  64. </div>
  65. </div>
  66. <div class="bottom">
  67. <div class="button-container">
  68. <button type="submit" class="pear-btn pear-btn-primary pear-btn-md" lay-submit="" lay-filter="save">
  69. 提交
  70. </button>
  71. <button type="reset" class="pear-btn pear-btn-md">
  72. 重置
  73. </button>
  74. </div>
  75. </div>
  76. </form>
  77. <script src="/app/admin/component/layui/layui.js?v=2.8.12"></script>
  78. <script src="/app/admin/component/pear/pear.js"></script>
  79. <script src="/app/admin/component/jsoneditor/jsoneditor.js"></script>
  80. <script src="/app/admin/admin/js/permission.js"></script>
  81. <script>
  82. // 相关接口
  83. const PRIMARY_KEY = "id";
  84. const SELECT_API = "/app/admin/pay-aisle/select" + location.search;
  85. const UPDATE_API = "/app/admin/pay-aisle/update";
  86. // 获取数据库记录
  87. layui.use(["form", "util", "popup"], function () {
  88. let $ = layui.$;
  89. $.ajax({
  90. url: SELECT_API,
  91. dataType: "json",
  92. success: function (res) {
  93. // 给表单初始化数据
  94. layui.each(res.data[0], function (key, value) {
  95. let obj = $('*[name="'+key+'"]');
  96. if (key === "password") {
  97. obj.attr("placeholder", "不更新密码请留空");
  98. return;
  99. }
  100. if (typeof obj[0] === "undefined" || !obj[0].nodeName) return;
  101. if (obj[0].nodeName.toLowerCase() === "textarea") {
  102. obj.val(value);
  103. } else {
  104. obj.attr("value", value);
  105. obj[0].value = value;
  106. }
  107. });
  108. // 字段 状态 state
  109. layui.use(["form"], function() {
  110. layui.$("#state").attr("checked", layui.$('input[name="state"]').val() != 0);
  111. layui.form.render();
  112. layui.form.on("switch(state)", function(data) {
  113. layui.$('input[name="state"]').val(this.checked ? 1 : 0);
  114. });
  115. })
  116. // 字段 图片 img
  117. layui.use(["upload", "layer"], function() {
  118. let input = layui.$("#img").prev();
  119. input.prev().attr("src", input.val());
  120. layui.$("#attachment-choose-img").on("click", function() {
  121. parent.layer.open({
  122. type: 2,
  123. title: "选择附件",
  124. content: "/app/admin/upload/attachment?ext=jpg,jpeg,png,gif,bmp",
  125. area: ["95%", "90%"],
  126. success: function (layero, index) {
  127. parent.layui.$("#layui-layer" + index).data("callback", function (data) {
  128. input.val(data.url).prev().attr("src", data.url);
  129. });
  130. }
  131. });
  132. });
  133. layui.upload.render({
  134. elem: "#img",
  135. acceptMime: "image/gif,image/jpeg,image/jpg,image/png",
  136. url: "/app/admin/upload/image",
  137. field: "__file__",
  138. done: function (res) {
  139. if (res.code > 0) return layui.layer.msg(res.msg);
  140. this.item.prev().val(res.data.url).prev().attr("src", res.data.url);
  141. }
  142. });
  143. });
  144. // ajax返回失败
  145. if (res.code) {
  146. layui.popup.failure(res.msg);
  147. }
  148. }
  149. });
  150. });
  151. //提交事件
  152. layui.use(["form", "popup"], function () {
  153. // 字段验证允许为空
  154. layui.form.verify({
  155. phone: [/(^$)|^1\d{10}$/, "请输入正确的手机号"],
  156. email: [/(^$)|^([a-zA-Z0-9_\.\-])+\@(([a-zA-Z0-9\-])+\.)+([a-zA-Z0-9]{2,4})+$/, "邮箱格式不正确"],
  157. url: [/(^$)|(^#)|(^http(s*):\/\/[^\s]+\.[^\s]+)/, "链接格式不正确"],
  158. number: [/(^$)|^\d+$/,'只能填写数字'],
  159. date: [/(^$)|^(\d{4})[-\/](\d{1}|0\d{1}|1[0-2])([-\/](\d{1}|0\d{1}|[1-2][0-9]|3[0-1]))*$/, "日期格式不正确"],
  160. identity: [/(^$)|(^\d{15}$)|(^\d{17}(x|X|\d)$)/, "请输入正确的身份证号"]
  161. });
  162. layui.form.on("submit(save)", function (data) {
  163. data.field[PRIMARY_KEY] = layui.url().search[PRIMARY_KEY];
  164. layui.$.ajax({
  165. url: UPDATE_API,
  166. type: "POST",
  167. dateType: "json",
  168. data: data.field,
  169. success: function (res) {
  170. if (res.code) {
  171. return layui.popup.failure(res.msg);
  172. }
  173. return layui.popup.success("操作成功", function () {
  174. parent.refreshTable();
  175. parent.layer.close(parent.layer.getFrameIndex(window.name));
  176. });
  177. }
  178. });
  179. return false;
  180. });
  181. });
  182. </script>
  183. </body>
  184. </html>