- List item
前言
平时在开发过程中,可能会遇到这么一种情况:
就是需要我们对一个结果集经常再次包装,包装成一个父子结构/树形结构,然后返回给前端。
这时候通常会需要编辑大量的代码才能将list组装成型,非常浪费时间,而且代码复用性不高,非常之不高,所以决定推广一个,简洁的,赏心悦目的方法
刚好最近有写了小功能,就直接呈现出来了。废话不多说,上菜 ~~
一、数据结构以及转换前后差异对比
1. 基础数据
2. 普通查询后结果集
3.调整转换之后的结果集
对面的小姐姐看过来,这里的代码真精彩 ~
二、创建实例
代码如下(示例):
/**
* 门店类型
* 我们通过实现 TreeNode 树模型接口,定义类就可以复用所有树形结构的场景了啦。
* 核心字段 必须满足 id,name,parentId,不满足的或者表结构不满足的我们需要
* 通过SQL union 出来 类似 图一 的一个数据列表出来(
* 相信大家知道怎么做,不知道的,可以私信我,如果是妹子可以手把手教学 ~。~)
*
*/
@Data
public class StoreType<T> implements TreeNode<String,StoreType> {
@ApiModelProperty(value = "id")
private String id;
@ApiModelProperty(value = "父级id")
private String parentId;
@ApiModelProperty(value = "名称")
private String name;
@ApiModelProperty(value = "孩子节点")
private List<StoreType> children;
}
// 言归正传 ,我们一起看下 TreeNode 接口的定义,
import java.io.Serializable;
import java.util.List;
/**
* 树模型 接口 表示树上一个节点
**/
public interface TreeNode<PK, T extends TreeNode> extends Serializable {
PK getId();
void setId(PK id);
PK getParentId();
void setParentId(PK parentId);
List<T> getChildren();
void setChildren(List<T> children);
}
// 看到这里,一些大佬可能有些不耐烦了,这只是一个普通的实现方式没什么特别的,
// 咱们往下接着看 O。O
三、提供一个工具类
此工具类 主要是通过HashMap对集合进行排序
代码如下(示例):
import com.gaia.belray.gis.common.IDUtil;
import org.apache.commons.collections4.CollectionUtils;
import java.util.ArrayList;
import java.util.HashMap;
import java.util.List;
import java.util.Map;
import java.util.concurrent.locks.ReentrantLock;
/**
* 树模型工具类 可将列表树转换成对象树,或者反向操作
**/
public class TreeParserUtils<E extends TreeNode> {
private List<E> tmpList;
private static TreeParserUtils instance;
private static ReentrantLock loc