update.html 13 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268
  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. <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="number" name="original_price" value="" class="layui-input">
  37. </div>
  38. </div>
  39. <div class="layui-form-item">
  40. <label class="layui-form-label">抵扣金额</label>
  41. <div class="layui-input-block">
  42. <input type="number" name="deduction_price" value="" class="layui-input">
  43. </div>
  44. </div>
  45. <div class="layui-form-item">
  46. <label class="layui-form-label">支付usd</label>
  47. <div class="layui-input-block">
  48. <input type="number" name="payment_usd" value="" class="layui-input">
  49. </div>
  50. </div>
  51. <div class="layui-form-item">
  52. <label class="layui-form-label">支付金额</label>
  53. <div class="layui-input-block">
  54. <input type="number" name="pay_price" value="" class="layui-input">
  55. </div>
  56. </div>
  57. <div class="layui-form-item">
  58. <label class="layui-form-label">每日利息</label>
  59. <div class="layui-input-block">
  60. <input type="number" name="bonus" value="" class="layui-input">
  61. </div>
  62. </div>
  63. <div class="layui-form-item">
  64. <label class="layui-form-label">原--每日利息</label>
  65. <div class="layui-input-block">
  66. <input type="number" name="original_bonus" value="" class="layui-input">
  67. </div>
  68. </div>
  69. <div class="layui-form-item">
  70. <label class="layui-form-label">解冻usd</label>
  71. <div class="layui-input-block">
  72. <input type="number" name="balance" value="" class="layui-input">
  73. </div>
  74. </div>
  75. <div class="layui-form-item">
  76. <label class="layui-form-label">原--解冻usd</label>
  77. <div class="layui-input-block">
  78. <input type="number" name="original_balance" value="" class="layui-input">
  79. </div>
  80. </div>
  81. <div class="layui-form-item">
  82. <label class="layui-form-label">剩余数量</label>
  83. <div class="layui-input-block">
  84. <input type="number" name="num" value="" class="layui-input">
  85. </div>
  86. </div>
  87. <div class="layui-form-item">
  88. <label class="layui-form-label">排序</label>
  89. <div class="layui-input-block">
  90. <input type="number" name="sort" value="" class="layui-input">
  91. </div>
  92. </div>
  93. <div class="layui-form-item">
  94. <label class="layui-form-label">状态</label>
  95. <div class="layui-input-block">
  96. <input type="checkbox" id="state" lay-filter="state" lay-skin="switch" />
  97. <input type="text" style="display:none" name="state" value="0" />
  98. </div>
  99. </div>
  100. <div class="layui-form-item">
  101. <label class="layui-form-label">描述</label>
  102. <div class="layui-input-block">
  103. <input type="text" name="describe" value="" class="layui-input">
  104. </div>
  105. </div>
  106. </div>
  107. </div>
  108. <div class="bottom">
  109. <div class="button-container">
  110. <button type="submit" class="pear-btn pear-btn-primary pear-btn-md" lay-submit="" lay-filter="save">
  111. 提交
  112. </button>
  113. <button type="reset" class="pear-btn pear-btn-md">
  114. 重置
  115. </button>
  116. </div>
  117. </div>
  118. </form>
  119. <script src="/app/admin/component/layui/layui.js?v=2.8.12"></script>
  120. <script src="/app/admin/component/pear/pear.js"></script>
  121. <script src="/app/admin/component/jsoneditor/jsoneditor.js"></script>
  122. <script src="/app/admin/admin/js/permission.js"></script>
  123. <script>
  124. // 相关接口
  125. const PRIMARY_KEY = "id";
  126. const SELECT_API = "/app/admin/good/select" + location.search;
  127. const UPDATE_API = "/app/admin/good/update";
  128. // 获取数据库记录
  129. layui.use(["form", "util", "popup"], function () {
  130. let $ = layui.$;
  131. $.ajax({
  132. url: SELECT_API,
  133. dataType: "json",
  134. success: function (res) {
  135. // 给表单初始化数据
  136. layui.each(res.data[0], function (key, value) {
  137. let obj = $('*[name="'+key+'"]');
  138. if (key === "password") {
  139. obj.attr("placeholder", "不更新密码请留空");
  140. return;
  141. }
  142. if (typeof obj[0] === "undefined" || !obj[0].nodeName) return;
  143. if (obj[0].nodeName.toLowerCase() === "textarea") {
  144. obj.val(value);
  145. } else {
  146. obj.attr("value", value);
  147. obj[0].value = value;
  148. }
  149. });
  150. // 字段 图片 img
  151. layui.use(["upload", "layer"], function() {
  152. let input = layui.$("#img").prev();
  153. input.prev().attr("src", input.val());
  154. layui.$("#attachment-choose-img").on("click", function() {
  155. parent.layer.open({
  156. type: 2,
  157. title: "选择附件",
  158. content: "/app/admin/upload/attachment?ext=jpg,jpeg,png,gif,bmp",
  159. area: ["95%", "90%"],
  160. success: function (layero, index) {
  161. parent.layui.$("#layui-layer" + index).data("callback", function (data) {
  162. input.val(data.url).prev().attr("src", data.url);
  163. });
  164. }
  165. });
  166. });
  167. layui.upload.render({
  168. elem: "#img",
  169. acceptMime: "image/gif,image/jpeg,image/jpg,image/png",
  170. url: "/app/admin/upload/image",
  171. field: "__file__",
  172. done: function (res) {
  173. if (res.code > 0) return layui.layer.msg(res.msg);
  174. this.item.prev().val(res.data.url).prev().attr("src", res.data.url);
  175. }
  176. });
  177. });
  178. // 字段 状态 0禁用1正常 state
  179. layui.use(["form"], function() {
  180. layui.$("#state").attr("checked", layui.$('input[name="state"]').val() != 0);
  181. layui.form.render();
  182. layui.form.on("switch(state)", function(data) {
  183. layui.$('input[name="state"]').val(this.checked ? 1 : 0);
  184. });
  185. })
  186. // 字段 产品类型 type
  187. layui.use(["jquery", "xmSelect"], function() {
  188. let value = layui.$("#type").attr("value");
  189. let initValue = value ? value.split(",") : [];
  190. layui.xmSelect.render({
  191. el: "#type",
  192. name: "type",
  193. filterable: true,
  194. initValue: initValue,
  195. data:[{'value':1,'name':'政策'},{'value':2,'name':'汽车'},{'value':3,'name':'手机'},{'value':4,'name':'生活'}],
  196. model: {"icon":"hidden","label":{"type":"text"}},
  197. clickClose: true,
  198. radio: true,
  199. })
  200. });
  201. // ajax返回失败
  202. if (res.code) {
  203. layui.popup.failure(res.msg);
  204. }
  205. }
  206. });
  207. });
  208. //提交事件
  209. layui.use(["form", "popup"], function () {
  210. // 字段验证允许为空
  211. layui.form.verify({
  212. phone: [/(^$)|^1\d{10}$/, "请输入正确的手机号"],
  213. email: [/(^$)|^([a-zA-Z0-9_\.\-])+\@(([a-zA-Z0-9\-])+\.)+([a-zA-Z0-9]{2,4})+$/, "邮箱格式不正确"],
  214. url: [/(^$)|(^#)|(^http(s*):\/\/[^\s]+\.[^\s]+)/, "链接格式不正确"],
  215. number: [/(^$)|^\d+$/,'只能填写数字'],
  216. date: [/(^$)|^(\d{4})[-\/](\d{1}|0\d{1}|1[0-2])([-\/](\d{1}|0\d{1}|[1-2][0-9]|3[0-1]))*$/, "日期格式不正确"],
  217. identity: [/(^$)|(^\d{15}$)|(^\d{17}(x|X|\d)$)/, "请输入正确的身份证号"]
  218. });
  219. layui.form.on("submit(save)", function (data) {
  220. data.field[PRIMARY_KEY] = layui.url().search[PRIMARY_KEY];
  221. layui.$.ajax({
  222. url: UPDATE_API,
  223. type: "POST",
  224. dateType: "json",
  225. data: data.field,
  226. success: function (res) {
  227. if (res.code) {
  228. return layui.popup.failure(res.msg);
  229. }
  230. return layui.popup.success("操作成功", function () {
  231. parent.refreshTable();
  232. parent.layer.close(parent.layer.getFrameIndex(window.name));
  233. });
  234. }
  235. });
  236. return false;
  237. });
  238. });
  239. </script>
  240. </body>
  241. </html>