本文主要是介绍hierarchy-utils 通用树形数据工具库,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!
通用树形数据工具库
- hierarchy-utils
- 链接地址
- 使用示例
- 数据结构 - 菜单
- 数据源
- 1.通过原数据结构返回树形数据
- 2.通过转换数据结构(Map / JSONObject)返回树形数据
- 3.返回源数据列表中id为rootId的元素或pid为rootId且id能整除2的全部子元素的数据列表 (支持将树形数据打平及过滤)
- 4.怎样对指定的返回结果列表进行排序的方法
hierarchy-utils
用于构建/查找具有层级关系树形数据的工具库,以解决业务中常见的树形数据处理需求
支持自定义过滤数据、排序及转换数据等
链接地址
https://github.com/joker-pper/hierarchy-utils
使用示例
数据结构 - 菜单
@Data
public class Menu {private Integer id;private String name;private Integer pid;private Integer sort;private List<Menu> children;
}
数据源
//查询当前用户的菜单列表List<Menu> menuList = menuService.findAllByUserId();//通过json转换List<Menu> menuList = JSONObject.parseArray(menuText, Menu.class);;
1.通过原数据结构返回树形数据
//默认根元素为-1 (当前所有一级菜单的pid为-1,可根据实际定义根元素使用)Integer rootId = -1;//排序(需注意业务属性值是否为空),可选Comparator<Menu> comparator = Comparator.comparingInt(Menu::getSort);HierarchyUtils.HierarchyFunctions<Menu, Integer, Menu> defaultFunctions = new HierarchyUtils.HierarchyFunctions<>();//获取piddefaultFunctions.setGetPidFunction(data -> data.getPid());//获取iddefaultFunctions.setGetIdFunction(data -> data.getId());//验证是否为rootdefaultFunctions.setIsRootFunction(id -> Objects.equals(rootId, id));//设置childrendefaultFunctions.setSetChildrenFunction((parent, children) -> {parent.setChildren(children);});//是否返回root元素(未设置时默认false,开启时root元素必须存在)defaultFunctions.setIsWithRoot(() -> false);//过滤条件(可选,用来筛选数据)defaultFunctions.setFilterPredicate(menu -> true);List<Menu> hierarchyResult = HierarchyUtils.getHierarchyResult(menuList,defaultFunctions,comparator);System.out.println(JSONObject.toJSONString(hierarchyResult));
2.通过转换数据结构(Map / JSONObject)返回树形数据
//默认根元素为-1 (当前所有一级菜单的pid为-1,可根据实际定义根元素使用)Integer rootId = -1;//排序(需注意业务属性值是否为空),可选Comparator<Menu> comparator = Comparator.comparingInt(Menu::getSort);HierarchyUtils.HierarchyFunctions<Menu, Integer, JSONObject> transferFunctions = new HierarchyUtils.HierarchyFunctions<>();//获取pidtransferFunctions.setGetPidFunction(data -> data.getPid());//获取idtransferFunctions.setGetIdFunction(data -> data.getId());//验证是否为roottransferFunctions.setIsRootFunction(id -> Objects.equals(rootId, id));//设置转换函数transferFunctions.setTransferFunction(menu -> {//转换数据JSONObject result = (JSONObject) JSON.toJSON(menu);//可定义或移除属性result.put("title", menu.getName());result.put("order", menu.getSort());result.put("newName", menu.getName());result.remove("name");return result;});//设置childrentransferFunctions.setSetChildrenFunction((parent, children) -> {parent.put("children", children);});//是否返回root元素(未设置时默认false,开启时root元素必须存在)transferFunctions.setIsWithRoot(() -> false);//过滤条件(可选,用来筛选数据)transferFunctions.setFilterPredicate(menu -> true);List<JSONObject> transferResults = HierarchyUtils.getHierarchyResult(menuList,transferFunctions,comparator);System.out.println(JSONObject.toJSONString(transferResults));
3.返回源数据列表中id为rootId的元素或pid为rootId且id能整除2的全部子元素的数据列表 (支持将树形数据打平及过滤)
Integer rootId = 1;HierarchyFlatUtils.HierarchyFlatFunctions<Menu, Integer, Menu> functions = new HierarchyFlatUtils.HierarchyFlatFunctions<>();//获取pidfunctions.setGetPidFunction(data -> data.getPid());//获取idfunctions.setGetIdFunction(data -> data.getId());//验证是否为rootfunctions.setIsRootFunction(id -> Objects.equals(rootId, id));//是否返回root元素(未设置时默认false,开启时root元素必须存在)functions.setIsWithRoot(() -> true);//是否返回全部的子元素(未设置时默认false,即默认只返回root元素的直接子元素)functions.setIsWithAllChildren(() -> true);//过滤条件(可选,用来筛选数据)functions.setFilterPredicate(menu -> menu.getId() % 2 == 0 || Objects.equals(rootId, menu.getId()));//排序(需注意业务属性值是否为空),可选Comparator<Menu> comparator = Comparator.comparingInt(Menu::getSort);List<Menu> matchResults = HierarchyFlatUtils.getHierarchyFlatResult(menuList,functions,comparator);//对返回结果排序(需注意业务属性值是否为空),可选HierarchySortUtils.sort(matchResults, comparator);System.out.println(JSONObject.toJSONString(matchResults));
4.怎样对指定的返回结果列表进行排序的方法
//对返回结果排序 (只排序当前列表,不会递归排序子元素)HierarchySortUtils.sort(list, comparator); //对返回结果及子元素排序(递归排序)HierarchySortUtils.sortWithChildren(list, childrenFunction, comparator);
这篇关于hierarchy-utils 通用树形数据工具库的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!