前一阵做的OA项目,有一个是组织架构的树,因为是分开做的,我做的是Controller和页面,其他组做的Service和Dao,因为之前一直没有商量页面用什么框架做比较好,导致,Dao层取出来的数据都不是Easyui Tree所能识别的,其实后台返回的也是树形的结构,但是他们返回的是name,,而不是Easyui Tree所能识别的text,他们返回的是****,,而不是Easyui Tree所能识别的children,因为别人已经做好了,所以也不方便让别人重新去定义格式,所以我这边只能通过转VO,把Service返回的对象重新进行封装,使之支持Easyui ,话不多说,直接上代码。

这段是VO代码;其中主要的就是ID,text,children,要转的就是这三个

public class OrganizationVo implements Serializable{

    private Integer id;
private Integer pid;
private Integer teamId;
private String text;
private String state;
private String leader;
private Integer sort;
private List<OrganizationVo> children; public OrganizationVo(){} public OrganizationVo(Integer id,Integer pid, Integer teamId,String leader,Integer sort,String text,String state, List<OrganizationVo> children) {
this.id = id;
this.pid = pid;
this.teamId = teamId;
this.text = text;
this.sort = sort;
this.leader = leader;
this.state = state;
this.children = children;
} public Integer getId() {
return id;
} public void setId(Integer id) {
this.id = id;
} public Integer getTeamId() {
return teamId;
} public void setTeamId(Integer teamId) {
this.teamId = teamId;
} public String getText() {
return text;
} public void setText(String text) {
this.text = text;
} public String getLeader() {
return leader;
} public void setLeader(String leader) {
this.leader = leader;
} public Integer getSort() {
return sort;
} public void setSort(Integer sort) {
this.sort = sort;
} public String getState() {
return state;
} public void setState(String state) {
this.state = state;
} public List<OrganizationVo> getChildren() {
return children;
} public void setChildren(List<OrganizationVo> children) {
this.children = children;
} public Integer getPid() {
return pid;
} public void setPid(Integer pid) {
this.pid = pid;
}
}

这个是转换的工具类(只要组织,不带成员)

public class TreeNoteUtil {

    /**
* 获取父节点菜单
* @param treesList 所有树菜单集合
* @return
*/
public final static List<OrganizationVo> getFatherNode(List<TeamOrganizational> treesList){
List<OrganizationVo> newTrees = new ArrayList<OrganizationVo>(); for (TeamOrganizational teamOrganizational : treesList) {
if (teamOrganizational.getFatherId()==null) {//如果pId为空,则该节点为父节点
//递归获取父节点下的子节点
OrganizationVo newTree = new OrganizationVo();
newTree.setId(teamOrganizational.getId());
newTree.setText(teamOrganizational.getName());
newTree.setTeamId(teamOrganizational.getTeamId()); List<TeamOrganizational> treesLists = teamOrganizational.getSonTeamOrganizationals();
newTree.setChildren(getChildrenNode(teamOrganizational.getId(), treesLists));
newTrees.add(newTree);
}
}
return newTrees;
} /**
* 递归获取子节点下的子节点
* @param pId 父节点的ID
* @param treesLists 所有菜单树集合
* @return
*/
private final static List<OrganizationVo> getChildrenNode(Integer pId, List<TeamOrganizational> treesLists){
List<OrganizationVo> newTrees = new ArrayList<OrganizationVo>(); for (TeamOrganizational mt : treesLists) {
if (mt.getFatherId() != null ) {
if (mt.getFatherId() == pId) {
OrganizationVo newTree = new OrganizationVo();
//递归获取子节点下的子节点,即设置树控件中的children
newTree.setChildren(getChildrenNode(mt.getId(), mt.getSonTeamOrganizationals()));
//设置树控件attributes属性的数据
newTree.setId(mt.getId());
newTree.setText(mt.getName());
newTree.setPid(mt.getFatherId());
newTree.setTeamId(mt.getTeamId());
newTree.setSort(mt.getSort());
newTree.setLeader(mt.getLeader());
newTrees.add(newTree);
}
}
}
return newTrees;
} }

这个是转换的工具类(带组织,带成员)

public class TreeNoteUtil2 {

    /**
* 获取父节点菜单
* @param treesList 所有树菜单集合
* @return
*/
public final static List<OrganizationVo> getFatherNode(List<TeamOrganizational> treesList){
List<OrganizationVo> newTrees = new ArrayList<OrganizationVo>(); for (TeamOrganizational teamOrganizational : treesList) { if (teamOrganizational.getFatherId()==null) {//如果pId为空,则该节点为父节点
//递归获取父节点下的子节点
OrganizationVo newTree = new OrganizationVo();
newTree.setId(teamOrganizational.getId());
newTree.setText(teamOrganizational.getName());
newTree.setTeamId(teamOrganizational.getTeamId()); List<TeamOrganizational> treesLists = teamOrganizational.getSonTeamOrganizationals();
List<OaUser> treesUserLists = teamOrganizational.getOaUsers();
newTree.setChildren(getChildrenNode(teamOrganizational.getId(), treesLists,treesUserLists));
newTrees.add(newTree);
}
} return newTrees;
} /**
* 递归获取子节点下的子节点
* @param pId 父节点的ID
* @param treesLists 所有菜单树集合
* @return
*/
private final static List<OrganizationVo> getChildrenNode(Integer pId, List<TeamOrganizational> treesLists,List<OaUser> treesUserLists) {
List<OrganizationVo> newTrees = new ArrayList<OrganizationVo>(); for (TeamOrganizational mt : treesLists) {
if (mt.getFatherId() != null) { if (mt.getFatherId() == pId) {
OrganizationVo newTree = new OrganizationVo();
//递归获取子节点下的子节点,即设置树控件中的children
newTree.setChildren(getChildrenNode(mt.getId(), mt.getSonTeamOrganizationals(),treesUserLists));
//设置树控件attributes属性的数据
newTree.setId(mt.getId());
newTree.setText(mt.getName());
newTree.setPid(mt.getFatherId());
newTree.setTeamId(mt.getTeamId());
newTree.setSort(mt.getSort());
newTree.setLeader(mt.getLeader());
if(mt.getOaUsers().size()>0){
newTree.setChildren(getOaUsers(mt.getOaUsers()));
}
newTrees.add(newTree);
}
}
}
if(treesUserLists.size()>0){
for (OaUser oaUser:treesUserLists){
OrganizationVo newTree = new OrganizationVo();
newTree.setId(oaUser.getId());
newTree.setText(oaUser.getRealname());
newTrees.add(newTree);
}
} return newTrees;
} public static List<OrganizationVo> getOaUsers(List<OaUser> oaUsers){
List<OrganizationVo> newTrees = new ArrayList<OrganizationVo>();
if (oaUsers.size()>0){
for (OaUser oaUser:oaUsers){
OrganizationVo newTree = new OrganizationVo();
newTree.setId(oaUser.getId());
newTree.setText(oaUser.getRealname());
newTrees.add(newTree);
}
}else{ }
return newTrees;
} }

代码就这么多,主要是运用了递归的思想,因为在你不知道有多少层级的情况下,还是用递归比较方便,虽然循环比递归的速度快,占用内存小,但递归还是有其优势的;

同时,仔细看那两个工具类,第二个工具类比第一个工具类多了添加员工的操作,但是这里就不会使用递归了,因为员工下面不会再有员工了,为什么我会强调这个,因为我先写的是第一个工具类,总想着如何递归,写第二个的时候,人员总是重复添加,好久都找不到原因,后来才忽然想到,员工下面是没有员工的,于是恍然大悟。。。。

Jquery EasyUI Tree树形结构的Java实现(实体转换VO)的更多相关文章

  1. Jquery easyui tree的使用

    这个ui用的一切都是json数据.树也是如此! 后台需要返回与格式匹配的json数据才能正确加载树. 页面定义一个ui: <ul id="messageInfoAddTree" ...

  2. 使用ztree.js,受益一生,十分钟学会使用tree树形结构插件

    看到ztree.js,这几个字眼,毋庸置疑,那肯定就是tree树形结构了,曾经的swing年代有jtree,后来jquery年代有jstree和treeview,虽然我没写过,但是我见过,一些小功能做 ...

  3. Jquery easyui Tree的简单使用

    Jquery easyui Tree的简单使用 Jquery easyui 是jQuery EasyUI是一组基于jQuery的UI插件集合,而jQuery EasyUI的目标就是帮助web开发者更轻 ...

  4. EasyUI之树形结构tree

    转自:https://blog.csdn.net/ya_1249463314/article/details/70305730 版权声明:本文为博主原创文章,未经博主允许不得转载. https://b ...

  5. salesforce 零基础学习(七十)使用jquery table实现树形结构模式

    项目中UI需要用到树形结构显示内容,后来尽管不需要做了,不过还是自己做着玩玩,mark一下,免得以后项目中用到. 实现树形结构在此使用的是jquery的dynatree.js.关于dynatree的使 ...

  6. jquery easyui tree dialog

    <script type="text/javascript" src="<%=request.getContextPath()%>/include/ja ...

  7. Jquery EasyUI Tree .net实例

    图片: 针对tree: 数据库: CREATE TABLE [dbo].[SystemModel]( [Id] [,) NOT NULL, [Name] [nvarchar]() NULL, [Fat ...

  8. Tree 树形结构

    一.树的基本概念 (1)树(Tree)的概念:树是一种递归定义的数据结构,是一种重要的非线性数据结构. 树可以是一棵空树,它没有任何的结点:也可以是一棵非空树,至少含有一个结点. (2)根(Root) ...

  9. Jquery easyui tree 一些常见操作

    Tree: easyui tree的异步加载实现很简单,easyui的中文API文档中有实例(http://api.btboys.com/easyui/)——创建异步树形菜单,就是在tree node ...

随机推荐

  1. C++中string的成员函数

    string类的构造函数: string(const char *s); //用c字符串s初始化 string(int n,char c); //用n个字符c初始化 此外,string类还支持默认构造 ...

  2. Django框架搭建(windows系统)

    Django框架搭建(windows系统) 一.Django简介 开放源代码的Web应用框架,由Python语言编写,一个大而全的框架. 1.web框架介绍 具体介绍Django之前,必须先介绍WEB ...

  3. 20145321 《Java程序设计》第5周学习总结

    20145321 <Java程序设计>第5周学习总结 教材学习内容总结 第八章 1.Try.catch:Java中所有错误都会被打包为对象,通过try和catch语法可以对代表错误的对象做 ...

  4. 20145322 《Java程序设计》第7周学习总结

    20145322何志威 <Java程序设计>第7周学习总结 教材学习内容总结 第十二章 如果使用JDK8的话,可以使用Lambda特性去除重复的信息. 在只有Lambda表达式的情况下,参 ...

  5. 51Nod 1521 一维战舰

    http://www.51nod.com/onlineJudge/questionCode.html#!problemId=1521 思路:先计算出一开始最多能放多少艘战舰,然后每次输入一个点后,找到 ...

  6. asp.net core + log4net+exceptionles+DI

    参考了ABP的代码,我也用依赖注入的原则,设计了日志模块. 与abp不同之处在于:1)DI容器使用的是.net core自带的注入容器,2)集成了excetpionless日志模块,3)不依赖于abp ...

  7. hdu 4602 Partition 矩阵快速幂

    Partition Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others) Proble ...

  8. mac下cordova的ios-deploy安装问题

    mac下进行cordova项目编译部署到ios设备,这个时候需要安装ios-deploy,会失败: npm WARN lifecycle ios-deploy@1.8.6~preinstall: ca ...

  9. PHP返回32位与16位的md5加密值

    字符串“123456”,经过md5算法加密之后是 32位: e10adc3949ba59abbe56e057f20f883e16位: 49ba59abbe56e057 PHP自带的 md5() 函数, ...

  10. JS/jQuery 遍历对象属性

    Javascript For/In 循环: 循环遍历对象的属性 var person={fname:"John",lname:"Doe",age:25}; fo ...