menu-detail.html 5.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169
  1. <!DOCTYPE html>
  2. <html>
  3. <head>
  4. <title>详情页</title>
  5. <!--#include file="common/_header.html"-->
  6. <link rel="stylesheet" type="text/css" href="lib/select2/select2.min.css" />
  7. </head>
  8. <body>
  9. <article class="page-container">
  10. <form class="form form-horizontal" id="form1">
  11. <input type="hidden" id="id" name="id">
  12. <div class="row cl">
  13. <label class="form-label col-xs-4 col-sm-3"><span class="c-red">*</span>菜单名称:</label>
  14. <div class="formControls col-xs-8 col-sm-9">
  15. <input type="text" class="input-text" id="menuName" name="menuName">
  16. </div>
  17. </div>
  18. <div class="row cl">
  19. <label class="form-label col-xs-4 col-sm-3"><span class="c-red">*</span>上级菜单:</label>
  20. <div class="formControls col-xs-8 col-sm-9">
  21. <select id="parentSelect" name="parentId" style="width:100%;" class="select2" data-placeholder="选择上级菜单">
  22. <option value=""></option>
  23. </select>
  24. </div>
  25. </div>
  26. <div class="row cl">
  27. <label class="form-label col-xs-4 col-sm-3"><span class="c-red">*</span>排序号:</label>
  28. <div class="formControls col-xs-8 col-sm-9">
  29. <input type="number" class="input-text" id="sortNo" name="sortNo">
  30. </div>
  31. </div>
  32. <div class="row cl">
  33. <label class="form-label col-xs-4 col-sm-3"><span class="c-red">*</span>访问方式</label>
  34. <div class="formControls col-xs-8 col-sm-9">
  35. <select id="method" class="select" name="method">
  36. <option value="GET">GET</option>
  37. <option value="POST">POST</option>
  38. </select>
  39. </div>
  40. </div>
  41. <div class="row cl">
  42. <label class="form-label col-xs-4 col-sm-3"><span class="c-red">*</span>菜单地址:</label>
  43. <div class="formControls col-xs-8 col-sm-9">
  44. <input type="text" class="input-text" id="menuUrl" name="menuUrl">
  45. </div>
  46. </div>
  47. <div class="row cl">
  48. <label class="form-label col-xs-4 col-sm-3"><span class="c-red">*</span>菜单类型:</label>
  49. <div class="formControls col-xs-8 col-sm-9">
  50. <select id="menuType" class="select" name="menuType">
  51. <option value="1">前端页面</option>
  52. <option value="2">后端接口</option>
  53. </select>
  54. </div>
  55. </div>
  56. <div class="row cl">
  57. <div class="col-xs-8 col-sm-9 col-xs-offset-4 col-sm-offset-3">
  58. <input class="btn btn-primary radius" type="submit" value="&nbsp;&nbsp;提交&nbsp;&nbsp;">
  59. </div>
  60. </div>
  61. </form>
  62. </article>
  63. <!--_footer 作为公共模版分离出去-->
  64. <!--#include file="common/_footer.html"-->
  65. <!--/_footer 作为公共模版分离出去-->
  66. <!--请在下方写此页面业务相关的脚本-->
  67. <script type="text/javascript" src="lib/jquery.validation/1.14.0/jquery.validate.js"></script>
  68. <script type="text/javascript" src="lib/jquery.validation/1.14.0/validate-methods.js"></script>
  69. <script type="text/javascript" src="lib/jquery.validation/1.14.0/messages_zh.js"></script>
  70. <script type="text/javascript" src="scripts/global.js"></script>
  71. <script type="text/javascript" src="lib/select2/select2.full.js"></script>
  72. <script type="text/javascript" src="lib/select2/select2.zh-CN.js"></script>
  73. <script type="text/javascript">
  74. var path = global_backend_url;
  75. $(document).ready(function(){
  76. //获取url中传参
  77. var id = getQueryString("id");
  78. var needLoad = false;
  79. var remoteUrl = path + "/menu/add";
  80. if(id!=null && id.length>0){
  81. remoteUrl = path + "/menu/update";
  82. needLoad = true;
  83. }
  84. $("#form1").validate({
  85. rules:{
  86. menuName:{
  87. required:true
  88. }
  89. },
  90. onkeyup:false,
  91. focusCleanup:true,
  92. success:"valid",
  93. submitHandler:function(form){
  94. $(form).ajaxSubmit({
  95. type: 'post',
  96. url: remoteUrl,
  97. success: function(data){
  98. if(data.result){
  99. top.layer.msg('添加成功!',{icon:1,time:1000});
  100. var index = parent.layer.getFrameIndex(window.name);
  101. if(index>=0){
  102. parent.reloadList();
  103. parent.layer.close(index);
  104. }
  105. }
  106. else{
  107. layer.msg(data.message,{icon:1,time:3000});
  108. }
  109. },
  110. error: function(XmlHttpRequest, textStatus, errorThrown){
  111. layer.msg('error!',{icon:1,time:3000});
  112. }
  113. });
  114. }
  115. });
  116. var menuOpts = {
  117. ajax: {
  118. url: global_backend_url + "/menu/query",
  119. dataType: 'json',
  120. delay: 250,
  121. method:'post',
  122. processResults: function (resp) {
  123. var results = resp.data.map(function(item){
  124. return {
  125. id : item.id,
  126. text : item.menuName
  127. }
  128. });
  129. return {
  130. results: results
  131. }
  132. }
  133. },
  134. language: "zh-CN",
  135. allowClear: true
  136. };
  137. $("#parentSelect").select2(menuOpts);
  138. if(needLoad){
  139. var loadingIndex = layer.load(1, {shade: [0.1,'#fff']});
  140. $.get(path + "/menu/detail/" + id,null, function(json){
  141. layer.close(loadingIndex);
  142. if(json.result){
  143. json2Form(json.data,"form1");
  144. var newOption = new Option(json.data.parentName, json.data.parentId, false, true);
  145. $('#parentSelect').append(newOption).trigger('change');
  146. }
  147. else{
  148. layer.msg(json.message);
  149. }
  150. },"json");
  151. }
  152. });
  153. </script>
  154. <!--/请在上方写此页面业务相关的脚本-->
  155. </body>
  156. </html>