手机
当前位置:查字典教程网 >编程开发 >Javascript教程 >基于jsTree的无限级树JSON数据的转换代码
基于jsTree的无限级树JSON数据的转换代码
摘要:jstree主页:http://www.jstree.com/其中提供了一种从后台取数据渲染成树的形式:复制代码代码如下:$("#mytre...

jstree 主页 :

http://www.jstree.com/

其中提供了一种从后台取数据渲染成树的形式:

复制代码 代码如下:

$("#mytree").tree({

data : {

type : "json",

url : "${ctx}/user/power!list.do"

}

});

对于url中返回的值必须是它定义的json数据形式:

复制代码 代码如下:

$("#demo2").tree({

data : {

type : "json",

json : [

{ attributes: { id : "pjson_1" }, state: "open", data: "Root node 1", children : [

{ attributes: { id : "pjson_2" }, data: { title : "Custom icon", icon : "../media/images/ok.png" } },

{ attributes: { id : "pjson_3" }, data: "Child node 2" },

{ attributes: { id : "pjson_4" }, data: "Some other child node" }

]},

{ attributes: { id : "pjson_5" }, data: "Root node 2" }

]

}

});

这里需要一个从后台实例集合转换为它规定的json数据的形式.

复制代码 代码如下:

/** *//**

* 无限递归获得jsTree的json字串

*

* @param parentId

* 父权限id

* @return

*/

private String getJson(long parentId)

{

// 把顶层的查出来

List<Action> actions = actionManager.queryByParentId(parentId);

for (int i = 0; i < actions.size(); i++)

{

Action a = actions.get(i);

// 有子节点

if (a.getIshaschild() == 1)

{

str += "{attributes:{id:"" + a.getAnid()

+ ""},state:"open",data:"" + a.getAnname() + "" ,";

str += "children:[";

// 查出它的子节点

List<Action> list = actionManager.queryByParentId(a.getAnid());

// 遍历它的子节点

for (int j = 0; j < list.size(); j++)

{

Action ac = list.get(j);

//还有子节点(递归调用)

if (ac.getIshaschild() == 1)

{

this.getJson(ac.getParentid());

}

else

{

str += "{attributes:{id:"" + ac.getAnid()

+ ""},state:"open",data:"" + ac.getAnname()

+ "" " + " }";

if (j < list.size() - 1)

{

str += ",";

}

}

}

str += "]";

str += " }";

if (i < actions.size() - 1)

{

str += ",";

}

}

}

return str;

}

调用:

复制代码 代码如下:

@org.apache.struts2.convention.annotation.Action(results =

{ @Result(name = "success", location = "/main/user/action-list.jsp") })

public String list()

{

String str = "[";

// 从根开始

str += this.getJson(0);

str += "]";

this.renderJson(str);

return null;

}

其中Action是菜单类或权限类等的实体。

效果图:

基于jsTree的无限级树JSON数据的转换代码1

【基于jsTree的无限级树JSON数据的转换代码】相关文章:

nodejs实现遍历文件夹并统计文件大小

javascript去除空格方法小结

无限扩展的年份select

使用RequireJS优化JavaScript引用代码的方法

JQuery中Text方法用法实例分析

简单的防盗链功能代码(iframe)

JS实现兼容各浏览器解析XML文档数据的方法

JavaScript基于setTimeout实现计数的方法

基于JavaScript实现动态添加删除表格的行

javascript字符串与数组转换汇总

精品推荐
分类导航