EasyUI tree 异步树与采用扁平化实现的同步树
所谓好记性不如烂笔头,为了以防忘记,才写下这篇博客,废话不多。。
异步树:
tips: 可以采用easyui里的原始数据格式,也可以采用扁平化的数据格式。
使用场景: 当菜单模块数量庞大或者无限极,最好使用异步树,单节点展开访问后台,返回对应的子菜单。
必须要件: 只需要一个URL即可
前台核心JS:
<script type="text/javascript">
$(function(){
$('#tt').tree({
url: 'MenuSynServlet',
lines:true/* ,
onLoadSuccess : function(node, data) {
var t = $(this);
if (data) {
$(data).each(function(index, d) {
if (this.state == 'closed') {
t.tree('expandAll');
}
});
}
} */
});
});
</script>
如果菜单比较少,也可以用异步树一次性加载 全部展开,把onLoadSuccess这段注释打开即可
后台Servlet:
@Override
protected void doPost(HttpServletRequest req, HttpServletResponse resp)
throws ServletException, IOException {
String key = req.getParameter("id");
DbUtil db= new DbUtil();
Connection conn = null;
List<EasyuiTreeNode> tree = new ArrayList<EasyuiTreeNode>();
if(StringUtil.isEmpty(key)){
try {
conn = db.getCon();
PreparedStatement ps = conn.prepareStatement("SELECT id,title FROM db_menus WHERE pid = 0");
ResultSet rs= ps.executeQuery();
while(rs.next()){
EasyuiTreeNode node = new EasyuiTreeNode();
node.setId(rs.getString("id"));
node.setState(existsText(conn,rs.getString("id"))? "closed":"open");
//如果想默认都是以文件夹形式显示,这样设置:node.setState("closed");
node.setTitle(rs.getString("title"));
tree.add(node);
}
} catch (Exception e) {
// TODO Auto-generated catch block
e.printStackTrace();
}finally{
try {
conn.close();
} catch (SQLException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}
}else{
try {
conn = db.getCon();
PreparedStatement ps = conn.prepareStatement("SELECT id,title FROM db_menus WHERE pid = ?");
ps.setString(1, key);
ResultSet rs= ps.executeQuery();
while(rs.next()){
EasyuiTreeNode node = new EasyuiTreeNode();
node.setId(rs.getString("id"));
node.setState((existsText(conn,key)? "open":"closed"));
node.setTitle(rs.getString("title"));
tree.add(node);
}
} catch (Exception e) {
// TODO Auto-generated catch block
e.printStackTrace();
}finally{
try {
conn.close();
} catch (SQLException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}
}
String json = JSON.toJSONString(tree);
resp.setContentType("text/html;charset=utf-8");
PrintWriter out=resp.getWriter();
out.println(json);
out.flush();
out.close();
}
private boolean existsText(Connection conn,String pid) throws SQLException{
PreparedStatement ps = conn.prepareStatement("SELECT COUNT(1) num FROM db_menus WHERE pid = ?");
boolean isClosed = true;
ps.setString(1, pid);
ResultSet rs = ps.executeQuery();
if(rs.next()){
String count = rs.getString("num");
if("0".equals(count)){
isClosed = false;
}
}
return isClosed;
}
}
同步树:
tips:这里采用扁平化的json格式实现,easyui tree 模仿ztree 使用扁平化加载json 原文链接:http://www.cnblogs.com/liaojie970/p/5319252.html
使用场景:菜单模块少 可以采用(PS:跟异步树一次性加载区别在于:同步树一次性加载 请求post一次,异步树因为采用了递归展开,请求post N次)
必须条件:数据格式要配制成ztree的数据格式(id,pid)
前台JS代码:
<script type="text/javascript" src="<%=basePath%>/js/jquery-easyui-1.5.1/plugins/jquery.tree_expand.js"></script>
<script type="text/javascript">
//实例化。这里增加了三个属性,可以指定idFiled,textFiled和parentField。所以这里的simpleData可以不严格转换成tree的数据格式。
$(function(){
$('#tt').tree({
url: 'MenuSynServlet',
parentField:"pid",
textFiled:"title",
idFiled:"id",
lines:true
});
});
</script>
后台Servlet代码:
@Override
protected void doPost(HttpServletRequest req, HttpServletResponse resp)
throws ServletException, IOException {
//String key = req.getParameter("id");
DbUtil db= new DbUtil();
Connection conn = null;
List<EasyuiTreeNode> tree = new ArrayList<EasyuiTreeNode>();
try {
conn = db.getCon();
PreparedStatement ps = conn.prepareStatement("SELECT id,pid,title FROM db_menus");
ResultSet rs= ps.executeQuery();
while(rs.next()){
EasyuiTreeNode node = new EasyuiTreeNode();
node.setId(rs.getString("id"));
node.setPid(rs.getString("pid"));
node.setState(existsText(conn,rs.getString("id"))? "closed":"open");
//如果想默认都是以文件夹形式显示,这样设置:node.setState("closed");
node.setTitle(rs.getString("title"));
tree.add(node);
}
} catch (Exception e) {
// TODO Auto-generated catch block
e.printStackTrace();
}finally{
try {
conn.close();
} catch (SQLException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}
String json = JSON.toJSONString(tree);
System.out.println(json);
resp.setContentType("text/html;charset=utf-8");
PrintWriter out=resp.getWriter();
out.println(json);
out.flush();
out.close();
}
private boolean existsText(Connection conn,String pid) throws SQLException{
PreparedStatement ps = conn.prepareStatement("SELECT COUNT(1) num FROM db_menus WHERE pid = ?");
boolean isClosed = true;
ps.setString(1, pid);
ResultSet rs = ps.executeQuery();
if(rs.next()){
String count = rs.getString("num");
if("0".equals(count)){
isClosed = false;
}
}
return isClosed;
}
附上数据脚本:
CREATE TABLE db_menus( id ) NOT NULL AUTO_INCREMENT, pid ) NOT NULL, title ) DEFAULT NULL, url ) DEFAULT NULL, PRIMARY KEY (id ) )ENGINE=INNODB DEFAULT CHARSET=utf8 COMMENT='菜单表' DROP TABLE db_menus ,'项目管理',NULL); ,'任务管理',NULL); ,'考勤管理',NULL); ,'报销管理',NULL); ,'绩效管理',NULL); ,'通讯录管理',NULL); ,'个人周报查询',NULL); ,'项目周报查询',NULL); ,'个人周报填写',NULL); ,'项目周报填写',NULL); ,'我的任务',NULL); ,'指定任务',NULL); ,'派出申请',NULL); ,'加班申请',NULL); ,'请假申请',NULL); ,'我的报销',NULL); ,'报销审批',NULL); ,'绩效考核填报',NULL); ,'绩效考核审核',NULL); ,'通讯录',NULL);
EasyUI tree 异步树与采用扁平化实现的同步树的更多相关文章
- spring mvc easyui tree 异步加载树
使用spring mvc 注解 异步加载一棵树 jsp: <ul id="orgInfoTree"></ul> $(function(){ loadOrgT ...
- jquery easyui tree异步加载子节点
easyui中的树可以从标记中建立,也可以通过指定一个URL属性读取数据建立.如果想建立一棵异步树,需要为每个节点指定一个id属性值,这样在加载数据时会自动向后台传递id参数. <ul id=& ...
- MVC4中EasyUI Tree异步加载JSON数据生成树
1,首先构造tree接受的格式化数据结构MODEL /// <summary> /// 定义EasyUI树的相关数据,方便控制器生成Json数据进行传递 /// </summar ...
- 16个时髦的扁平化设计的 HTML5 & CSS3 网站模板
创建网站最好办法之一是使用现成的网站模板或使用开源 CMS 应用程序.所以,今天这篇文章给大家带来的是16款基于 HTML5 & CSS3 的精美的扁平风格网站模板,大家可以借助这些优秀的网站 ...
- [转]easyui tree 模仿ztree 使用扁平化加载json
原文地址:http://my.oschina.net/acitiviti/blog/349377 参考文章:http://www.jeasyuicn.com/demo/treeloadfilter.h ...
- 数据网格和树-EasyUI Datagrid 数据网格、EasyUI Propertygrid 属性网格、EasyUI Tree 树、EasyUI Treegrid 树形网格
EasyUI Datagrid 数据网格 扩展自 $.fn.panel.defaults.通过 $.fn.datagrid.defaults 重写默认的 defaults. 数据网格(datagrid ...
- 【EasyUI学习-2】Easyui Tree的异步加载
作者:ssslinppp 1. 摘要 2. tree的相关介绍 3. 异步加载tree数据,并实现tree的折叠展开 3.1 功能说明: 3.2 前台代码 3.3 后台代码 4. 其他 1 ...
- EasyUI Tree 树
转自:http://www.jeasyui.net/plugins/185.html 通过 $.fn.tree.defaults 重写默认的 defaults. 树(tree)在网页中以树形结构显示分 ...
- ASP.NET MVC5+EF6+EasyUI 后台管理系统(50)-Easyui 扁平化皮肤
最近抽了点时间仿做了点皮肤,只供欣赏!扁平化
随机推荐
- P2910 [USACO08OPEN]寻宝之路Clear And Present Danger 洛谷
https://www.luogu.org/problem/show?pid=2910 题目描述 Farmer John is on a boat seeking fabled treasure on ...
- codevs——1385 挤牛奶
1385 挤牛奶 USACO 时间限制: 1 s 空间限制: 128000 KB 题目等级 : 青铜 Bronze 题解 查看运行结果 题目描述 Description 三个农民每天清 ...
- SpringBoot使用logback自定义配置时遇到的坑 --- 在 /tmp目录下自动生成spring.log文件
问题描述 SpringBoot项目使用logback自定义配置后,会在/tmp/ 目录下生成 spring.log的文件(如下图所示). 解决方案 通过各种资料的搜索,最终发现问题的所在(logbac ...
- Linux简单口令
创建文件1.touch2.echo "">>file_name3.vim 文件名创建文件夹1.mkdir -p /abc/cc/bbb删除文件rm -f 文件删除文件夹 ...
- 洛谷 U41571 Agent2
U41571 Agent2 题目背景 炎炎夏日还没有过去,Agent们没有一个想出去外面搞事情的.每当ENLIGHTENED总部组织活动时,人人都说有空,结果到了活动日,却一个接着一个咕咕咕了.只有不 ...
- LENOVO System x3850 X6
http://appserver.lenovo.com.cn/Lenovo_Series_List.aspx?CategoryCode=A31B01
- [React] Use Prop Collections with Render Props
Sometimes you have common use cases that require common props to be applied to certain elements. You ...
- Python循环定时服务功能(相似contrab)
Python实现的循环定时服务功能.类似于Linux下的contrab功能.主要通过定时器实现. 注:Python中的threading.timer是基于线程实现的.每次定时事件产生时.回调完响应函数 ...
- websphere修改jsp不生效的解决办法
最近在给客户部署系统后,进行UAT测试的时候,发现一些小问题(是一些jsp文件),改好后,就进行增量发布了,可是后来在页面刷新的时候,怎么都是显示不出来效果,后来就把服务websphere重启后,页面 ...
- iOS开发——swift——swift与OC之间不得不知道的21点
swift与OC之间不得不知道的21点 自6月的WWDC大会上由苹果的大神Chris Lattner向我们首次展示swift至今已经大半年时间了,虽然绝大部分软件公司代码里还都见不到一丁点swif ...