java后端把数据转换为树,map递归生成json树,返回给前端(后台转换)

发布于 2020-8-17|标签java
复制链接
摘记: java 后端,把数据转换为树,map递归生成一颗json树,返回给前端(后台转换)1.为什么要写这样的一篇博客?2.java 后端代码3. 转化完的数据在前端格式为类似于:1.为什么要写这样的一篇博客?在公司的实习的时候,遇到了一个略坑的东西,就是 ..
java 后端,把数据转换为树,map递归生成一颗json树,返回给前端(后台转换)1.为什么要写这样的一篇博客?2.java 后端代码3. 转化完的数据在前端格式为类似于:1.为什么要写这样的一篇博客?在公司的实习的时候,遇到了一个略坑的东西,就是要医院的科室通过其子父id做成一颗项目树,但是科室的层次有很多,有点甚至到了六层,导致最终选择了优化后的递归算法。如果在三层或者三层以下,可以考虑使用内部类,超过三层的话,最好就使用递归了,不过记得必须的优化。2.java 后端代码代码的解释和理解我卸载代码里面,返回到前端会自动转换成Json格式的数据。 ```java //第一个参数,需要生成树的数组,第二个参数为树的根节点 public JSONObject getJsontree(JSONArray json,JSONObject job){ JSONArray tempJson = JSONArray.fromObject("[]"); //筛选出父id等于job里面id的科室 for(int i = 0;i 3. 转化完的数据在前端格式为类似于: ```java [ { text: '节点1', children: [ { text: '节点1.1' }, { text: '节点1.2' }, { text: '节点1.3', children: [ { text: '节点1.3.1' }, { text: '节点1.3.2' } ] }, { text: '节点1.4' } ] } ] ``` 补充知识:java将list转为树形结构的方法1、通过转化成json封装数据 ```java [ { "name":"甘肃省", "pid":0, "id":1 }, { "name":"天水市", "pid":1, "id":2 }, { "name":"秦州区", "pid":2, "id":3 }, { "name":"北京市", "pid":0, "id":4 }, { "name":"昌平区", "pid":4, "id":5 } ] ``` 现需要是使用java将以上数据转为树形结构,转化后下的结构如下 ```java [ { "children":[ { "children":[ { "name":"秦州区", "pid":2, "id":3 } ], "name":"天水市", "pid":1, "id":2 } ], "name":"甘肃省", "pid":0, "id":1 }, { "children":[ { "name":"昌平区", "pid":4, "id":5 } ], "name":"北京市", "pid":0, "id":4 } ] ``` 代码如下 ```java import com.alibaba.fastjson.JSON; import com.alibaba.fastjson.JSONArray; import com.alibaba.fastjson.JSONObject; public static JSONArray listToTree(JSONArray arr, String id, String pid, String child) { JSONArray r = new JSONArray(); JSONObject hash = new JSONObject(); //将数组转为Object的形式,key为数组中的id for (int i = 0; i > data = new ArrayList(); Map map = new HashMap(); map.put("id",1); map.put("pid",0); map.put("name","甘肃省"); data.add(map); Map map2 = new HashMap(); map2.put("id",2); map2.put("pid",1); map2.put("name","天水市"); data.add(map2); Map map3 = new HashMap(); map3.put("id",3); map3.put("pid",2); map3.put("name","秦州区"); data.add(map3); Map map4 = new HashMap(); map4.put("id",4); map4.put("pid",0); map4.put("name","北京市"); data.add(map4); Map map5 = new HashMap(); map5.put("id",5); map5.put("pid",4); map5.put("name","昌平区"); data.add(map5); System.out.println(JSON.toJSONString(data)); JSONArray result = listToTree(JSONArray.parseArray(JSON.toJSONString(data)),"id","pid","children"); System.out.println(JSON.toJSONString(result)); } ```
冀ICP备17029012号-4 | 版权所有©鲍亚龙 |免责声明  | GIF图库  | NUXT版