基于springboot+bootstrap+mysql+redis搭建一套完整的权限架构【七】【菜单维护模块】

https://blog.csdn.net/linzhefeng89/article/details/78770142

                    版权声明:本文为博主原创文章,未经博主允许不得转载。                        https://blog.csdn.net/linzhefeng89/article/details/78770142                    </div>
                                                <link rel="stylesheet" href="https://csdnimg.cn/release/phoenix/template/css/ck_htmledit_views-cd6c485e8b.css">
                                    <link rel="stylesheet" href="https://csdnimg.cn/release/phoenix/template/css/ck_htmledit_views-cd6c485e8b.css">
            <div class="htmledit_views" id="content_views">

       大家在阅读本章的时候大家一定要把上一章的代码从GitHub上拿下来先,因此本章的以及后续章节的所有的Java代码都是基于上一章节的代码因此大家一定要记得把上一章的代码全部给clone下来,否则本章的代码大家将无法运行起来。

       通过上一章节我们已经完成了我们的基本架构的开发工作,那么这一章我们将开发我们的菜单维护模块,实现对菜单的增删改查的功能,该模块的菜单树使用的是ztree的前端js的代码,首先在我们开发该模块的时候我们需要到WebMvcConfig中增加如下配置:


接着我们开始编写我们的菜单模块的代码首先建如下的文件路径,同时我们实现我们的菜单维护的业务逻辑:


首先是treeList.html的页面的代码(该页面使用了bootstrap和ztree)


 
 
  1. <html xmlns:th="http://www.thymeleaf.org"
  2. >
  3. <head th:include="include/includebase"> </head>
  4. <body>
  5. <div id="content" class="row-fluid">
  6. <div class="col-md-3 " style="margin-top: 10px;">
  7. <ul id="menu_tree" class="ztree" style="width:560px; overflow:auto;"> </ul>
  8. </div>
  9. </div>
  10. <script th:inline="javascript">
  11. var zTree;
  12. var demoIframe;
  13. var selectNode;
  14. function addHoverDom(treeId, treeNode) {
  15. var sObj = $( "#" + treeNode.tId + "_span");
  16. if (treeNode.editNameFlag || $( "#addBtn_"+treeNode.tId).length> 0) return;
  17. var addStr = "<span class='button remove' id='removeBtn_" + treeNode.tId + "' title='add node' οnfοcus='this.blur();'></span>";
  18. addStr += "<span class='button add' id='addBtn_" + treeNode.tId + "'></span>";
  19. addStr += "<span class='button edit' id='editBtn_" + treeNode.tId + "'></span>";
  20. if(treeNode.isParent){
  21. addStr += "<span class='button add' id='addParentBtn_" + treeNode.tId + "'></span>";
  22. }
  23. sObj.after(addStr);
  24. var btn = $( "#addBtn_"+treeNode.tId);
  25. if (btn) btn.bind( "click", function(){
  26. zTree = $.fn.zTree.getZTreeObj( "menu_tree");
  27. selectNode = treeNode;
  28. window.Ewin.dialog({ title: "添加", url: "tree/addTreePage?id="+treeNode.id, width: 400, height: 650})
  29. return false;
  30. });
  31. var remove_btn = $( "#removeBtn_"+treeNode.tId);
  32. if (remove_btn) remove_btn.bind( "click", function() {
  33. zTree = $.fn.zTree.getZTreeObj( "menu_tree");
  34. if (treeNode.isParent) {
  35. window.Ewin.alert({ message: "请先删除当前菜单节点底下的子菜单!"});
  36. } else{
  37. window.Ewin.confirm({ title: '提示', message: '是否要删除您当前选中的菜单节点?', width: 500}).on( function (e) {
  38. if (e) {
  39. $.post( "tree/remove",{ id:treeNode.id}, function(e){
  40. if(e.result){
  41. zTree.removeNode(treeNode);
  42. window.Ewin.alert({ message:e.msg});
  43. } else{
  44. window.Ewin.alert({ message:e.msg});
  45. }
  46. })
  47. }
  48. });
  49. }
  50. return false;
  51. });
  52. var edit_btn = $( "#editBtn_"+treeNode.tId);
  53. if (edit_btn) edit_btn.bind( "click", function(){
  54. zTree = $.fn.zTree.getZTreeObj( "menu_tree");
  55. selectNode = treeNode;
  56. window.Ewin.dialog({ title: "修改", url: "tree/updateTreePage?id="+treeNode.id, width: 400, height: 650})
  57. return false;
  58. });
  59. var add_parent_btn = $( "#addParentBtn_"+treeNode.tId);
  60. if (add_parent_btn) add_parent_btn.bind( "click", function(){
  61. zTree = $.fn.zTree.getZTreeObj( "menu_tree");
  62. selectNode = null;
  63. window.Ewin.dialog({ title: "添加", url: "tree/addTreePage", width: 400, height: 650})
  64. return false;
  65. })
  66. };
  67. function removeHoverDom(treeId, treeNode) {
  68. $( "#addBtn_"+treeNode.tId).unbind().remove();
  69. $( "#removeBtn_"+treeNode.tId).unbind().remove();
  70. $( "#editBtn_"+treeNode.tId).unbind().remove();
  71. $( "#addParentBtn_"+treeNode.tId).unbind().remove();
  72. };
  73. var setting = {
  74. check: {
  75. enable: false
  76. },
  77. view: {
  78. addHoverDom: addHoverDom,
  79. removeHoverDom: removeHoverDom,
  80. dblClickExpand: false,
  81. showLine: true,
  82. selectedMulti: false
  83. },
  84. data: {
  85. simpleData: {
  86. enable: true,
  87. idKey: "id",
  88. pIdKey: "pId",
  89. rootPId: "0"
  90. }
  91. },
  92. callback: {
  93. beforeClick: function(treeId, treeNode) {
  94. var zTree = $.fn.zTree.getZTreeObj( 'menu_tree');
  95. if (treeNode.isParent) {
  96. zTree.expandNode(treeNode);
  97. return false;
  98. } else {
  99. return true;
  100. }
  101. }
  102. }
  103. };
  104. function loadReady() {
  105. var bodyH = demoIframe.contents().find( "body").get( 0).scrollHeight,
  106. htmlH = demoIframe.contents().find( "html").get( 0).scrollHeight,
  107. maxH = Math.max(bodyH, htmlH), minH = Math.min(bodyH, htmlH),
  108. h = demoIframe.height() >= maxH ? minH:maxH;
  109. if (h < 530){
  110. h = 530;
  111. }
  112. demoIframe.height(h);
  113. }
  114. $( function() {
  115. $.post( "/tree/loadUserTree", function(info){
  116. var t = $( "#menu_tree");
  117. t = $.fn.zTree.init(t, setting,info.data);
  118. })
  119. });
  120. </script>
  121. </body>
  122. </html>
接着是add.html增加菜单的页面的代码:


 
 
  1. <html xmlns:th="http://www.thymeleaf.org"
  2. xmlns:sec= "http://www.thymeleaf.org/thymeleaf-extras-springsecurity4">
  3. <body>
  4. <form id="treeForm" role="form" method="post" action="tree/save">
  5. <input type="hidden" name="pId" th:value="${entity.id}" />
  6. <div class="form-group" >
  7. <label >父菜单名称: </label>
  8. <input type="text" class="form-control" th:value="${entity.name}" readonly="readonly" />
  9. </div>
  10. <div class="form-group">
  11. <label for="name">菜单名称: </label>
  12. <input type="text" class="form-control" name="name" id="name" placeholder="请输入菜单名称" />
  13. </div>
  14. <div class="form-group">
  15. <label for="url">菜单地址: </label>
  16. <input type="text" class="form-control" name="url" id="url" placeholder="请输入菜单地址" />
  17. </div>
  18. <div class="form-group">
  19. <label for="icon">菜单样式: </label>
  20. <input type="text" class="form-control" name="icon" id="icon" placeholder="请输入菜单样式" />
  21. </div>
  22. <div class="form-group">
  23. <label for="url">菜单编码: </label>
  24. <input type="text" class="form-control" name="code" id="code" placeholder="请输入菜单编码" />
  25. </div>
  26. <div class="form-group">
  27. <label for="treeOrder">菜单顺序: </label>
  28. <input type="text" class="form-control" name="treeOrder" id="treeOrder" placeholder="请输入菜单顺序" />
  29. </div>
  30. <div class="form-group">
  31. <label >菜单状态: </label>
  32. <label class='radio-inline'> <input type='radio' name='state' value='1' checked="checked" />可用 </label>
  33. <label class='radio-inline'> <input type='radio' name='state' value='0' />禁用 </label>
  34. </div>
  35. </form>
  36. <script th:inline="javascript">
  37. <![CDATA[
  38. $( function () {
  39. $( '#treeForm').bootstrapValidator({
  40. message: 'This value is not valid',
  41. feedbackIcons: {
  42. valid: 'glyphicon glyphicon-ok',
  43. invalid: 'glyphicon glyphicon-remove',
  44. validating: 'glyphicon glyphicon-refresh'
  45. },
  46. fields: {
  47. name: {
  48. message: '菜单名称验证失败',
  49. validators: {
  50. notEmpty: {
  51. message: '菜单名称不能为空'
  52. }
  53. }
  54. },
  55. url: {
  56. message: '菜单地址验证失败',
  57. validators: {
  58. notEmpty: {
  59. message: '菜单地址不能为空'
  60. }
  61. }
  62. },
  63. code: {
  64. message: '菜单编码验证失败',
  65. validators: {
  66. notEmpty: {
  67. message: '菜单编码不能为空'
  68. }
  69. }
  70. },
  71. treeOrder: {
  72. message: '菜单顺序验证失败',
  73. validators: {
  74. notEmpty: {
  75. message: '菜单顺序不能为空'
  76. },
  77. regexp: {
  78. regexp: /^[0-9_]+$/,
  79. message: '菜单顺序必须为数字'
  80. },
  81. stringLength: {
  82. min: 1,
  83. max: 18,
  84. message: '菜单顺序必须在1到18位之间'
  85. }
  86. }
  87. }
  88. }
  89. })
  90. // 绑定dialog的确定按钮的监听事件
  91. $( "#btnOk", window.top.document).click( function() {
  92. var bootstrapValidator = $( "#treeForm", window.top.document).data( 'bootstrapValidator');
  93. bootstrapValidator.validate();
  94. if(bootstrapValidator.isValid()){
  95. var zTree = $( window.parent.document).contents().find( ".tab-pane.fade.active.in iframe")[ 0].contentWindow.zTree;
  96. var selectNode = $( window.parent.document).contents().find( ".tab-pane.fade.active.in iframe")[ 0].contentWindow.selectNode;
  97. $.post($( "#treeForm", window.top.document).attr( 'action'),$( "#treeForm", window.top.document).serialize(), function(e){
  98. if(e.result){
  99. $( '.modal-dialog', window.top.document).parent( 'div').remove()
  100. $( 'body', window.top.document).find( '.modal-backdrop').remove();
  101. var entity = e.entity;
  102. zTree.addNodes(selectNode, { id:entity.id, pId:entity.pId, name:entity.name});
  103. window.Ewin.alert({ message: '增加数据成功!'});
  104. } else{
  105. window.Ewin.alert({ message: '增加数据失败!'});
  106. }
  107. })
  108. }
  109. });
  110. })
  111. ]]>
  112. </script>
  113. </body>
  114. </html>

最后是update.html修改菜单页面的代码:


 
 
  1. <html xmlns:th="http://www.thymeleaf.org"
  2. xmlns:sec= "http://www.thymeleaf.org/thymeleaf-extras-springsecurity4">
  3. <body>
  4. <form id="treeForm" role="form" method="post" action="tree/update">
  5. <input type="hidden" name="pId" th:value="${entity.tree.id}" />
  6. <input type="hidden" name="id" th:value="${entity.id}" />
  7. <div class="form-group" >
  8. <label >父菜单名称: </label>
  9. <input type="text" class="form-control" th:value="${entity.tree.name}" readonly="readonly" />
  10. </div>
  11. <div class="form-group">
  12. <label for="name">菜单名称: </label>
  13. <input type="text" class="form-control" name="name" id="name" th:value="${entity.name}" placeholder="请输入菜单名称" />
  14. </div>
  15. <div class="form-group">
  16. <label for="url">菜单地址: </label>
  17. <input type="text" class="form-control" name="url" id="url" th:value="${entity.url}" placeholder="请输入菜单地址" />
  18. </div>
  19. <div class="form-group">
  20. <label for="icon">菜单样式: </label>
  21. <input type="text" class="form-control" name="icon" id="icon" th:value="${entity.icon}" placeholder="请输入菜单样式" />
  22. </div>
  23. <div class="form-group">
  24. <label for="url">菜单编码: </label>
  25. <input type="text" class="form-control" name="code" id="code" th:value="${entity.code}" placeholder="请输入菜单编码" />
  26. </div>
  27. <div class="form-group">
  28. <label for="treeOrder">菜单顺序: </label>
  29. <input type="text" class="form-control" name="treeOrder" id="treeOrder" th:value="${entity.treeOrder}" placeholder="请输入菜单顺序" />
  30. </div>
  31. <div class="form-group">
  32. <label for="treeOrder">菜单状态: </label>
  33. <label class='radio-inline'> <input type='radio' name='state' value='1' th:checked="${entity.state} == 1?true:false" />可用 </label>
  34. <label class='radio-inline'> <input type='radio' name='state' value='0' th:checked="${entity.state} == 0?true:false" />禁用 </label>
  35. </div>
  36. </form>
  37. <script th:inline="javascript">
  38. <![CDATA[
  39. $( function () {
  40. $( '#treeForm').bootstrapValidator({
  41. message: 'This value is not valid',
  42. feedbackIcons: {
  43. valid: 'glyphicon glyphicon-ok',
  44. invalid: 'glyphicon glyphicon-remove',
  45. validating: 'glyphicon glyphicon-refresh'
  46. },
  47. fields: {
  48. name: {
  49. message: '菜单名称验证失败',
  50. validators: {
  51. notEmpty: {
  52. message: '菜单名称不能为空'
  53. }
  54. }
  55. },
  56. url: {
  57. message: '菜单地址验证失败',
  58. validators: {
  59. notEmpty: {
  60. message: '菜单地址不能为空'
  61. }
  62. }
  63. },
  64. code: {
  65. message: '菜单编码验证失败',
  66. validators: {
  67. notEmpty: {
  68. message: '菜单编码不能为空'
  69. }
  70. }
  71. },
  72. treeOrder: {
  73. message: '菜单顺序验证失败',
  74. validators: {
  75. notEmpty: {
  76. message: '菜单顺序不能为空'
  77. },
  78. regexp: {
  79. regexp: /^[0-9_]+$/,
  80. message: '菜单顺序必须为数字'
  81. },
  82. stringLength: {
  83. min: 1,
  84. max: 18,
  85. message: '菜单顺序必须在1到18位之间'
  86. }
  87. }
  88. }
  89. }
  90. })
  91. // 绑定dialog的确定按钮的监听事件
  92. $( "#btnOk", window.top.document).click( function() {
  93. var bootstrapValidator = $( "#treeForm", window.top.document).data( 'bootstrapValidator');
  94. bootstrapValidator.validate();
  95. if(bootstrapValidator.isValid()){
  96. var zTree = $( window.parent.document).contents().find( ".tab-pane.fade.active.in iframe")[ 0].contentWindow.zTree;
  97. var selectNode = $( window.parent.document).contents().find( ".tab-pane.fade.active.in iframe")[ 0].contentWindow.selectNode;
  98. $.post($( "#treeForm", window.top.document).attr( 'action'),$( "#treeForm", window.top.document).serialize(), function(e){
  99. if(e.result){
  100. $( '.modal-dialog', window.top.document).parent( 'div').remove()
  101. $( 'body', window.top.document).find( '.modal-backdrop').remove();
  102. var entity = e.entity;
  103. selectNode.name = entity.name;
  104. zTree.updateNode(selectNode);
  105. window.Ewin.alert({ message: '修改数据成功!'});
  106. } else{
  107. window.Ewin.alert({ message: '修改数据失败!'});
  108. }
  109. })
  110. }
  111. });
  112. })
  113. ]]>
  114. </script>
  115. </body>
  116. </html>

到此我们完成了菜单模块的开发工作,由于java代码我们在上一章已经完成了全部的开发因此此处就不再继续陈述了,开发完成以后大家可以直接运行程序查看结果如下:

本章代码的GitHub地址:https://github.com/185594-5-27/csdndemo/tree/master-base-tree


上一篇文章地址:基于springboot+bootstrap+mysql+redis搭建一套完整的权限架构【六】【引入bootstrap前端框架】


下一篇文章地址:基于springboot+bootstrap+mysql+redis搭建一套完整的权限架构【八】【完善整个项目】


QQ交流群:578746866



评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

hello_world!

你的鼓励将是我创作的最大动力!

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值