一、创建TreeNodes实体类
import com.alibaba.druid.util.StringUtils;
import java.util.ArrayList;
import java.util.List;
public class TreeNodes implements Comparable<TreeNodes> {
//实现Comparable接口,实现根据level排序
//实体类主键(必须字段),用于与上级绑定
private String id;
//父级ID(必须字段),用于与下级绑定
private String pId;
//实体类层级(必须字段)
private String level;
//实体类名称(非必须,可替换为其它一个或多个参数)
private String text;
private List<TreeNodes> children = new ArrayList<>();
public TreeNodes() {
}
;
/**
* @param id 一般为主键
* @param pId 父id
* @param text 标签名称
* @param level 层级
*/
public TreeNodes(String id, String pId, String text, String level) {
this.id = StringUtils.isEmpty(id) ? "id" : id;
this.pId = StringUtils.isEmpty(pId) ? "pId" : pId;
this.text = StringUtils.isEmpty(text) ? "text" : text;//非必须,可替换为其它一个或多个参数
this.level = StringUtils.isEmpty(level) ? "level" : level;
}
@Override
public int compareTo(TreeNodes tn) {
//1排在当前的后面//-1排在当前的前面
int big = 1, small = -1, eq = 0;
if (tn == null || tn.getLevel() == null) {
return big;
} else if (this.getLevel() == null) {
return small;
} else if (Integer.valueOf(tn.getLevel()) < Integer.valueOf(this.getLevel())) {
return big;
} else if (Integer.valueOf(tn.getLevel()) > Integer.valueOf(this.getLevel())) {
return small;
}
return eq;
}
//省略getter、setter方法
}
二、引入fastJson包
maven引入fastJson
<dependency>
<groupId>com.alibaba</groupId>
<artifactId>druid</artifactId>
<version>1.1.12</version>
</dependency>
<dependency>
<groupId>com.alibaba</groupId>
<artifactId>fastjson</artifactId>
<version>1.2.47</version>
</dependency>
纯JAVA项目可以直接下载fastjson.jar
com.alibaba.druid.jar
,导入项目
三、工具类
注:如果转换为树仍为原类型(User-->User
,而不是User-->TreeNodes
),只需修改formatTree
方法里标有//change
注释的地方,将条件修改为自己匹配的条件即可;