update.html 8.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224
  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" readonly="readonly" 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="mobile" 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="text" name="pid_mobile" 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="password" value="" class="layui-input">
  36. </div>
  37. </div>
  38. </div>
  39. </div>
  40. <div class="bottom">
  41. <div class="button-container">
  42. <button type="submit" class="pear-btn pear-btn-primary pear-btn-md" lay-submit="" lay-filter="save">
  43. 提交
  44. </button>
  45. <button type="reset" class="pear-btn pear-btn-md">
  46. 重置
  47. </button>
  48. </div>
  49. </div>
  50. </form>
  51. <script src="/app/admin/component/layui/layui.js?v=2.8.12"></script>
  52. <script src="/app/admin/component/pear/pear.js"></script>
  53. <script src="/app/admin/component/jsoneditor/jsoneditor.js"></script>
  54. <script src="/app/admin/admin/js/permission.js"></script>
  55. <script>
  56. // 相关接口
  57. const PRIMARY_KEY = "id";
  58. const SELECT_API = "/app/admin/user/select" + location.search;
  59. const UPDATE_API = "/app/admin/user/update";
  60. // 获取数据库记录
  61. layui.use(["form", "util", "popup"], function () {
  62. let $ = layui.$;
  63. $.ajax({
  64. url: SELECT_API,
  65. dataType: "json",
  66. success: function (res) {
  67. // 给表单初始化数据
  68. layui.each(res.data[0], function (key, value) {
  69. let obj = $('*[name="'+key+'"]');
  70. if (key === "password") {
  71. obj.attr("placeholder", "不更新密码请留空");
  72. return;
  73. }
  74. if (key === "fund_code") {
  75. obj.attr("placeholder", "不更新密码请留空");
  76. return;
  77. }
  78. if (typeof obj[0] === "undefined" || !obj[0].nodeName) return;
  79. if (obj[0].nodeName.toLowerCase() === "textarea") {
  80. obj.val(value);
  81. } else {
  82. obj.attr("value", value);
  83. obj[0].value = value;
  84. }
  85. });
  86. // 字段 头像 avatar
  87. layui.use(["upload", "layer"], function() {
  88. let input = layui.$("#avatar").prev();
  89. input.prev().attr("src", input.val());
  90. layui.$("#attachment-choose-avatar").on("click", function() {
  91. parent.layer.open({
  92. type: 2,
  93. title: "选择附件",
  94. content: "/app/admin/upload/attachment?ext=jpg,jpeg,png,gif,bmp",
  95. area: ["95%", "90%"],
  96. success: function (layero, index) {
  97. parent.layui.$("#layui-layer" + index).data("callback", function (data) {
  98. input.val(data.url).prev().attr("src", data.url);
  99. });
  100. }
  101. });
  102. });
  103. layui.upload.render({
  104. elem: "#avatar",
  105. url: "/app/admin/upload/avatar",
  106. acceptMime: "image/gif,image/jpeg,image/jpg,image/png",
  107. field: "__file__",
  108. done: function (res) {
  109. if (res.code > 0) return layui.layer.msg(res.msg);
  110. this.item.prev().val(res.data.url).prev().attr("src", res.data.url);
  111. }
  112. });
  113. });
  114. // 字段 登录时间 last_time
  115. layui.use(["laydate"], function() {
  116. layui.laydate.render({
  117. elem: "#last_time",
  118. type: "datetime",
  119. });
  120. })
  121. // 字段 注册时间 join_time
  122. layui.use(["laydate"], function() {
  123. layui.laydate.render({
  124. elem: "#join_time",
  125. type: "datetime",
  126. });
  127. })
  128. // 字段 状态 1正常 2 冻结 status
  129. layui.use(["form"], function() {
  130. layui.$("#status").attr("checked", layui.$('input[name="status"]').val() != 0);
  131. layui.form.render();
  132. layui.form.on("switch(status)", function(data) {
  133. layui.$('input[name="status"]').val(this.checked ? 1 : 0);
  134. });
  135. })
  136. // 字段 实名: 1未实名 2已实名 is_autonym
  137. layui.use(["jquery", "xmSelect"], function() {
  138. let value = layui.$("#is_autonym").attr("value");
  139. let initValue = value ? value.split(",") : [];
  140. layui.xmSelect.render({
  141. el: "#is_autonym",
  142. name: "is_autonym",
  143. filterable: true,
  144. initValue: initValue,
  145. model: {"icon":"hidden","label":{"type":"text"}},
  146. clickClose: true,
  147. radio: true,
  148. })
  149. });
  150. // 字段 创建时间 created_at
  151. layui.use(["laydate"], function() {
  152. layui.laydate.render({
  153. elem: "#created_at",
  154. type: "datetime",
  155. });
  156. })
  157. // ajax返回失败
  158. if (res.code) {
  159. layui.popup.failure(res.msg);
  160. }
  161. }
  162. });
  163. });
  164. //提交事件
  165. layui.use(["form", "popup"], function () {
  166. // 字段验证允许为空
  167. layui.form.verify({
  168. phone: [/(^$)|^1\d{10}$/, "请输入正确的手机号"],
  169. email: [/(^$)|^([a-zA-Z0-9_\.\-])+\@(([a-zA-Z0-9\-])+\.)+([a-zA-Z0-9]{2,4})+$/, "邮箱格式不正确"],
  170. url: [/(^$)|(^#)|(^http(s*):\/\/[^\s]+\.[^\s]+)/, "链接格式不正确"],
  171. number: [/(^$)|^\d+$/,'只能填写数字'],
  172. date: [/(^$)|^(\d{4})[-\/](\d{1}|0\d{1}|1[0-2])([-\/](\d{1}|0\d{1}|[1-2][0-9]|3[0-1]))*$/, "日期格式不正确"],
  173. identity: [/(^$)|(^\d{15}$)|(^\d{17}(x|X|\d)$)/, "请输入正确的身份证号"]
  174. });
  175. layui.form.on("submit(save)", function (data) {
  176. data.field[PRIMARY_KEY] = layui.url().search[PRIMARY_KEY];
  177. layui.$.ajax({
  178. url: UPDATE_API,
  179. type: "POST",
  180. dateType: "json",
  181. data: data.field,
  182. success: function (res) {
  183. if (res.code) {
  184. return layui.popup.failure(res.msg);
  185. }
  186. return layui.popup.success("操作成功", function () {
  187. parent.refreshTable();
  188. parent.layer.close(parent.layer.getFrameIndex(window.name));
  189. });
  190. }
  191. });
  192. return false;
  193. });
  194. });
  195. </script>
  196. </body>
  197. </html>