java树形菜单对象生成

本文实例为大家分享了java树形菜单对象生成的具体代码,供大家参考,具体内容如下

1、TreeNode对象

package com.ruoyi.system.utils.Vo;

import java.util.ArrayList;
import java.util.List;

public class TreeNode {

  /**
   * 节点ID
   */
  private Integer id;

  /**
   * 节点名称
   */
  private String name;

  /**
   * 父节点ID
   */
  private Integer parentId;

  /**
   * 子节点列表
   */
  private List childrenList = new ArrayList();

  public Integer getId() {
    return id;
  }

  public void setId(Integer id) {
    this.id=id;
  }

  public String getName() {
    return name;
  }

  public void setName(String name) {
    this.name=name;
  }

  public Integer getParentId() {
    return parentId;
  }

  public void setParentId(Integer parentId) {
    this.parentId=parentId;
  }

  public List getChildrenList() {
    return childrenList;
  }

  public void setChildrenList(List childrenList) {
    this.childrenList=childrenList;
  }
}

2、TreeUtil

package com.ruoyi.system.utils;

import com.ruoyi.system.utils.Vo.TreeNode;

import java.util.ArrayList;
import java.util.List;

public class TreeUtil {

  private List<TreeNode> treeNodeList =new ArrayList<>();

  public TreeUtil(List<TreeNode> list){
    treeNodeList = list;
  }

  /**
   * 获取节点信息
   * @param nodeId 节点ID
   * @return
   */
  public TreeNode getNodeById(int nodeId){
    TreeNode treeNode = new TreeNode();
    for (TreeNode item : treeNodeList) {
      if (item.getId() == nodeId) {
        treeNode = item;
        break;
      }
    }
    return treeNode;
  }

  /**
   * 获取子节点信息
   * @param nodeId 节点ID
   * @return
   */
  public List<TreeNode> getChildrenNodeById(int nodeId){
    List<TreeNode> childrenTreeNode = new ArrayList<TreeNode>();
    for (TreeNode item : treeNodeList) {
      if(item.getParentId() == nodeId){
        childrenTreeNode.add(item);
      }
    }
    return childrenTreeNode;
  }

  /**
   * 递归生成Tree结构数据
   * @param rootId 根节点ID
   * @return
   */
  public TreeNode generateTreeNode(int rootId){
    TreeNode root = this.getNodeById(rootId);
    List<TreeNode> childrenTreeNode = this.getChildrenNodeById(rootId);
    for (TreeNode item : childrenTreeNode) {
      TreeNode node = this.generateTreeNode(item.getId());
      root.getChildrenList().add(node);
    }
    return root;
  }

  public static void main(String[] args) {
    List<TreeNode> nodeList = new ArrayList<>();
    TreeNode treeNode = new TreeNode();
    treeNode.setId(1);
    treeNode.setName("中国");
    treeNode.setParentId(0);
    nodeList.add(treeNode);
    treeNode = new TreeNode();
    treeNode.setId(2);
    treeNode.setName("北京市");
    treeNode.setParentId(1);
    nodeList.add(treeNode);
    treeNode = new TreeNode();
    treeNode.setId(3);
    treeNode.setName("浙江省");
    treeNode.setParentId(1);
    nodeList.add(treeNode);
    treeNode = new TreeNode();
    treeNode.setId(4);
    treeNode.setName("杭州市");
    treeNode.setParentId(3);
    nodeList.add(treeNode);
    treeNode = new TreeNode();
    treeNode.setId(5);
    treeNode.setName("西湖区");
    treeNode.setParentId(4);
    nodeList.add(treeNode);
    treeNode = new TreeNode();
    treeNode.setId(6);
    treeNode.setName("滨江区");
    treeNode.setParentId(4);
    nodeList.add(treeNode);
    treeNode = new TreeNode();
    treeNode.setId(7);
    treeNode.setName("金华市");
    treeNode.setParentId(3);
    nodeList.add(treeNode);
    TreeUtil treeUtil = new TreeUtil(nodeList);
    treeNode = treeUtil.generateTreeNode(1);
    System.out.println("树状结构Json格式数据:" + JsonUtils.objectToJson(treeNode, 1));
  }
}

3、JsonUtil

package com.ruoyi.system.utils;

import com.fasterxml.jackson.core.JsonProcessingException;
import com.fasterxml.jackson.databind.JavaType;
import com.fasterxml.jackson.databind.ObjectMapper;

import java.util.List;

public class JsonUtils {

  // 定义jackson对象
  private static final ObjectMapper MAPPER = new ObjectMapper();

  /**
   * 将对象转换成json字符串
   * @param obj 需转换的对象
   * @param  flag Json格式化标识(0-否,1-是)
   * @return
   */
  public static <T> String objectToJson(T obj, int flag) {
    if (obj == null) {
      return null;
    }
    try {
      String string;
      if (flag == 1) {
        string = obj instanceof String ? (String) obj : MAPPER.writerWithDefaultPrettyPrinter().writeValueAsString(obj);
      } else {
        string = obj instanceof String ? (String) obj : MAPPER.writeValueAsString(obj);
      }
      return string;
    } catch (JsonProcessingException e) {
      e.printStackTrace();
    }
    return null;
  }

  /**
   * 将json结果集转化为对象
   *
   * @param jsonData json数据
   * @param beanType 对象中的object类型
   * @return
   */
  public static <T> T jsonToPojo(String jsonData, Class<T> beanType) {
    try {
      T t = MAPPER.readValue(jsonData, beanType);
      return t;
    } catch (Exception e) {
      e.printStackTrace();
    }
    return null;
  }

  /**
   * 将json数据转换成pojo对象list
   * <p>Title: jsonToList</p>
   * <p>Description: </p>
   * @param jsonData
   * @param beanType
   * @return
   */
  public static <T>List<T> jsonToList(String jsonData, Class<T> beanType) {
    JavaType javaType = MAPPER.getTypeFactory().constructParametricType(List.class, beanType);
    try {
      List<T> list = MAPPER.readValue(jsonData, javaType);
      return list;
    } catch (Exception e) {
      e.printStackTrace();
    }

    return null;
  }

  public static void main(String[] args) {
    System.out.println("测试字符串对象:" + objectToJson("hello world", 1));
  }

}

4、运行结果

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持我们。

(0)

相关推荐

  • java编程两种树形菜单结构的转换代码

    首先看看两种树形菜单结构的代码示例. SingleTreeNode: package com.zzj.tree; public class SingleTreeNode { private int id; private int pId; private String name; public SingleTreeNode() { } public SingleTreeNode(int id, int pId, String name) { this.id = id; this.pId = pI

  • Java递归如何正确输出树形菜单

    本文实例为大家分享了java递归输出树形菜单的具体代码,供大家参考,具体内容如下 首先我们要建立树节点的类: package com.tree; public class Node { private Integer id; private Integer parentId; private String name; private String link; public Integer getId() { return id; } public void setId(Integer id) {

  • java实现遍历树形菜单两种实现代码分享

    文本主要向大家分享了java实现遍历树形菜单的实例代码,具体如下. OpenSessionView实现: package org.web; import java.io.IOException; import javax.servlet.Filter; import javax.servlet.FilterChain; import javax.servlet.FilterConfig; import javax.servlet.ServletException; import javax.se

  • java实现树形菜单对象

    本文实例为大家分享了java实现树形菜单对象的具体代码,供大家参考,具体内容如下 1.SysMenu package com.zy.shiro.domain; import com.baomidou.mybatisplus.annotation.IdType; import com.baomidou.mybatisplus.annotation.TableField; import com.baomidou.mybatisplus.annotation.TableId; import com.f

  • Java构建树形菜单的实例代码(支持多级菜单)

    效果图:支持多级菜单. 菜单实体类: public class Menu { // 菜单id private String id; // 菜单名称 private String name; // 父菜单id private String parentId; // 菜单url private String url; // 菜单图标 private String icon; // 菜单顺序 private int order; // 子菜单 private List<Menu> children;

  • java实现构造无限层级树形菜单

    这里来讲一下后台java如何构造多叉树,这样前台就可接收到数据递归构造树形菜单了. 我们来理一下如何实现构造多叉树的逻辑吧,其实整个问题概括起来就是 1.构造一个实体类,用来存储节点,所以我们构造的需要四个对象(id,pid,name,和chirenList) 2.构造菜单结构 3.构造子菜单,如此循环,通过pid判断上级菜单 具体实现: 1.这里构造Tree.java实体类 package com.tcl.jr.crm.entity; /** * 类名称:Tree * 类描述:树形结构 */

  • java利用递归调用实现树形菜单的样式

    一:需求 现有以需求就是把某一个帖子的全部评论展示出来. 二:分析 关于对帖子的评论分为主评论和子评论,主评论就是对帖子的直接评论,子评论就是对评论的评论. 三:思路 先获取某一个帖子的全部主评论,递归判断是否有子评论,获取子评论. 递归本质:程序调用自身的编程技巧叫做递归. 程序调用自身的编程技巧称为递归( recursion).递归做为一种算法在程序设计语言中广泛应用. 一个过程或函数在其定义或说明中有直接或间接调 用自身的一种方法,它通常把一个大型复杂的问题层层转化为一个与原问题相似的规模

  • Java树形菜单的创建

    功能:实现创建一个树形菜单 说明:创建树形菜单结构与创建菜单栏类似,是按层次与模型创建的. 通过DefaultMutableTreeNode类创建根节点.子节点和孙节点对象,再通过DefaultTreeModel 类利用根节点创建树模型对象,然后通过treeModel.insertNodeInto方法将节点对象插入树模型中. 效果图: 代码: import java.awt.*; import javax.swing.*; import javax.swing.tree.*; import ja

  • java树形菜单对象生成

    本文实例为大家分享了java树形菜单对象生成的具体代码,供大家参考,具体内容如下 1.TreeNode对象 package com.ruoyi.system.utils.Vo; import java.util.ArrayList; import java.util.List; public class TreeNode { /** * 节点ID */ private Integer id; /** * 节点名称 */ private String name; /** * 父节点ID */ pr

  • JAVA递归生成树形菜单的实现过程

    递归生成一个如图的菜单,编写两个类数据模型Menu.和创建树形的MenuTree.通过以下过程实现: 1.首先从菜单数据中获取所有根节点. 2.为根节点建立次级子树并拼接上. 3.递归为子节点建立次级子树并接上,直至为末端节点拼接上空的“树”. 首先,编写数据模型Menu.每条菜单有自己的id.父节点parentId.菜单名称text.菜单还拥有次级菜单children. import java.util.List; public class Menu { private String id;

  • Java树形结构数据生成导出excel文件方法记录

    目录 什么是树形结构数据 效果 用法 源码 总结 什么是树形结构数据 效果 用法 String jsonStr = "{\"name\":\"aaa\",\"children\":[{\"name\":\"bbb\",\"children\":[{\"name\":\"eee\"},{\"name\":\"f

  • asp.net TreeView递归循环子节点生成树形菜单实例

    本文实例讲述了asp.net TreeView递归循环子节点生成树形菜单的方法.分享给大家供大家参考,具体如下: 这里主要用到递归循环获取子结点 /// <summary> /// 生成根节点 /// </summary> /// <param name="treeview"></param> protected void BindTreeView(long ID, TreeView treeview) { DataTable dt =

  • JavaScript递归算法生成树形菜单

    本文实例为大家分享了js生成树形菜单的具体代码,供大家参考,具体内容如下 1.最终效果图(这里仅为实现算法,并加载至页面,不做任何css界面优化) 注释:本示例包含三级目录菜单,但实际上可支持N级(可使用该代码自行测试) 2.数据源 菜单信息一般来源于数据库中数据表,且为自连接表,其中包含主要字段(主键,菜单名称,父级id): 本示例在前端页面中使用对象数组模拟从数据库获取菜单信息: var menuArry = [ { id: 1, name: "办公管理", pid: 0 }, {

  • javascript动态生成树形菜单的方法

    本文实例讲述了javascript动态生成树形菜单的方法.分享给大家供大家参考,具体如下: //======================================== //Envrionment to hold Listeners //======================================== tv_listeners = new Array() ; function listener( type , handler ) { this.type = type ;

随机推荐