Grails显示树形结构
2014-05-03 00:00
573 查看
摘要: 树形结构是一个常用的结构,本文展示了Grails下显示树形结构的一种尝试。
两个步骤
1.首先实现树形结构的领域类。
2.前端显示。
表征树形结构的领域类:
直接在领域类内实现树形结构,采用两个函数,第一个是主函数(String treeView())负责调用递归函数,并返回值。
第二个是递归函数(formTreeView),负责递归整个树,并生成字符串。
class SystemMenu {
String menuContext
String menuAction
SystemMenu upMenuItem
static hasMany = [menuItems: SystemMenu]
static constraints = {
menuContext(unique:true)
menuAction()
upMenuItem(nullable:true)
}
String toString() {
return "${menuContext}"
}
String treeView() {
StringBuilder sb = new StringBuilder();
//append(getId()).
sb.append("<ul>");
formTreeView(sb, menuItems);
sb.append("</ul>");
return sb.toString();
}
void formTreeView(sb, menuItems) {
for (SystemMenu e: menuItems) {
sb.append("<li>abc");
sb.append(e.menuContext);
if (e.menuItems) {
sb.append("<ul>");
formTreeView(sb, e.menuItems);
sb.append("</ul>");
}
sb.append("</li>");
}
}
}
2.树形结构的前端显示
实现这一目标采用jsTree控件,一个jQuery的插件,下载地址:http://www.jstree.com/
Grails网站所推荐的插件方式没有成功
下载jsTree
将所需的css文件放到\grails-app\assets\stylesheets\目录下;
js文件放到\grails-app\assets\javascripts\目录下。
在gsp文件的Head段内增加如下内容
<!--Include a jsTree theme-->
<asset:stylesheet href="themes/default/style.min.css"/>
<!--Include jQuery,由于Grails自己有jQuery的内容,所以这一步可以省略-->
<!--Include jsTree-->
<asset:javascript src="jstree.min.js"/>
<!--实现树形结构-->
<script type = "text/javascript" >
$(function () { $('#tree').jstree(); });
</script>
显示树形结构的最后一步是这样的:
<g:treeView item="${systemMenuInstance}"></g:treeView>
这里调用的是一个自己写的标签
class MenuTagLib {
//static defaultEncodeAs = 'html'
//static encodeAsForTags = [tagName: 'raw']
def treeView = {attrs, body->
def SystemMenu item = attrs['item']
out << "<div id=\"tree\">"
out << item.treeView()
out << "</div>"
}
}
两个步骤
1.首先实现树形结构的领域类。
2.前端显示。
表征树形结构的领域类:
直接在领域类内实现树形结构,采用两个函数,第一个是主函数(String treeView())负责调用递归函数,并返回值。
第二个是递归函数(formTreeView),负责递归整个树,并生成字符串。
class SystemMenu {
String menuContext
String menuAction
SystemMenu upMenuItem
static hasMany = [menuItems: SystemMenu]
static constraints = {
menuContext(unique:true)
menuAction()
upMenuItem(nullable:true)
}
String toString() {
return "${menuContext}"
}
String treeView() {
StringBuilder sb = new StringBuilder();
//append(getId()).
sb.append("<ul>");
formTreeView(sb, menuItems);
sb.append("</ul>");
return sb.toString();
}
void formTreeView(sb, menuItems) {
for (SystemMenu e: menuItems) {
sb.append("<li>abc");
sb.append(e.menuContext);
if (e.menuItems) {
sb.append("<ul>");
formTreeView(sb, e.menuItems);
sb.append("</ul>");
}
sb.append("</li>");
}
}
}
2.树形结构的前端显示
实现这一目标采用jsTree控件,一个jQuery的插件,下载地址:http://www.jstree.com/
Grails网站所推荐的插件方式没有成功
下载jsTree
将所需的css文件放到\grails-app\assets\stylesheets\目录下;
js文件放到\grails-app\assets\javascripts\目录下。
在gsp文件的Head段内增加如下内容
<!--Include a jsTree theme-->
<asset:stylesheet href="themes/default/style.min.css"/>
<!--Include jQuery,由于Grails自己有jQuery的内容,所以这一步可以省略-->
<!--Include jsTree-->
<asset:javascript src="jstree.min.js"/>
<!--实现树形结构-->
<script type = "text/javascript" >
$(function () { $('#tree').jstree(); });
</script>
显示树形结构的最后一步是这样的:
<g:treeView item="${systemMenuInstance}"></g:treeView>
这里调用的是一个自己写的标签
class MenuTagLib {
//static defaultEncodeAs = 'html'
//static encodeAsForTags = [tagName: 'raw']
def treeView = {attrs, body->
def SystemMenu item = attrs['item']
out << "<div id=\"tree\">"
out << item.treeView()
out << "</div>"
}
}
相关文章推荐
- 在myeclipse中包名显示成树形结构
- 将数据库的树形结构的数据,转成JSON,用于树形列表显示
- linux 用树形命令tree 显示文件目录结构及处理CRT显示乱码问题
- 修改eclipse中包的显示结构为树形
- EXCEL树形结构显示
- 在DropDownList中显示树形结构
- linux下怎么用tree命令以树形结构显示文件目录结构?
- Linux下C编程-----IO/文件操作 模拟linux ls程序显示文件系统树形结构(2)
- 得到对象调用的其他对象,显示为树形结构
- Qt中树形结构显示目录结构
- DropDownList中显示无限级树形结构
- 在DropDownList中显示树形结构
- Redmine 父子问题树形结构显示技巧
- Oracle 层级语句 树形结构 显示根节点 不显示根节点
- 部门树形结构,使用Treeview控件显示部门
- 如何以树形结构显示文件目录结构
- dropdownlist显示树形结构
- 在同一个下拉列表显示树形结构
- DropDownList 中显示树形结构内容
- Python显示目录的树形结构