日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

java实现多级菜单(java递归)方法二

發布時間:2023/12/31 编程问答 23 豆豆
生活随笔 收集整理的這篇文章主要介紹了 java实现多级菜单(java递归)方法二 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.
@Autowiredprivate TreeBuilder treeBuilder; /*** 獲取樹狀結構數據*/@RequestMapping("menu/queryMenuTree")@ResponseBodypublic Object queryMenuTree(int id){//查詢Node數據List<Node> list=menuService.queryMenuTree();//根據角色查詢關聯到的菜單List<RoleMenu> roleMenus=menuService.queryMenuByRoleId(id);//渲染已經選中內容for(RoleMenu rm:roleMenus){//獲取當前對象的idint menuId=rm.getMenuId();for(Node node:list){if(node.getId()==menuId){node.setChecked(true);}}}//組裝樹結構String result =treeBuilder.buildTree(list);return result;} @Component("treeBuilder") public class TreeBuilder {List<Node> nodes = new ArrayList<>();public String buildTree(List<Node> nodes) {TreeBuilder treeBuilder = new TreeBuilder(nodes);return treeBuilder.buildJSONTree();}public TreeBuilder() {}public TreeBuilder(List<Node> nodes) {super();this.nodes = nodes;}// 構建JSON樹形結構public String buildJSONTree() {List<Node> nodeTree = buildTree();String jsonStr = JSON.toJSONString(nodeTree);return jsonStr;}// 構建樹形結構public List<Node> buildTree() {List<Node> treeNodes = new ArrayList<>();List<Node> rootNodes = getRootNodes();for (Node rootNode : rootNodes) {buildChildNodes(rootNode);treeNodes.add(rootNode);}return treeNodes;}// 遞歸子節點public void buildChildNodes(Node node) {List<Node> children = getChildNodes(node);if (!children.isEmpty()) {for (Node child : children) {buildChildNodes(child);}node.setChildren(children);}}// 獲取父節點下所有的子節點public List<Node> getChildNodes(Node pnode) {List<Node> childNodes = new ArrayList<>();for (Node n : nodes) {if (pnode.getId().equals(n.getParentId())) {childNodes.add(n);}}return childNodes;}// 判斷是否為根節點public boolean rootNode(Node node) {boolean isRootNode = true;for (Node n : nodes) {if (node.getParentId().equals(n.getId())) {isRootNode = false;break;}}return isRootNode;}// 獲取集合中所有的根節點public List<Node> getRootNodes() {List<Node> rootNodes = new ArrayList<>();for (Node n : nodes) {System.out.println(n);if (rootNode(n)) {rootNodes.add(n);}}return rootNodes;}} @Data public class Node {private Integer id;private Integer parentId;private String title;private List<Node> children;private Boolean checked;//是否選中public Integer getId() {return id;}public void setId(Integer id) {this.id = id;}public Integer getParentId() {return parentId;}public void setParentId(Integer parentId) {this.parentId = parentId;}public String getTitle() {return title;}public void setTitle(String title) {this.title = title;}public List<Node> getChildren() {return children;}public void setChildren(List<Node> children) {this.children = children;}public Boolean getChecked() {return checked;}public void setChecked(Boolean checked) {this.checked = checked;} }

總結

以上是生活随笔為你收集整理的java实现多级菜单(java递归)方法二的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。