jqxtree异步加载部门树
整体思路
A.要想实现异步加载第一次加载的是一级部门
B.加载一级部门,如果有子部门,部门前面带+号,没有子部门,部门前面没有+号(+号也就是点击可以展开)
C.在sql中实现如果有子部门默认都加载一个子部门名称为“查询中...”的部门,id自己定唯一就行,这样就可以实现加载的一级部门到底前面带不带+号
D.当点击可以展开的部门时,将部门为“查询中...”的替换为异步查出来的部门
1.引入样式和js(差不多能用到的都引入吧以便以后能用到)
<link rel="stylesheet" href="<%=basePath%>sg/jqwidgets/styles/jqx.base.css" type="text/css" />
<script type="text/javascript" src="<%=basePath%>/sg/jqwidgets/jqxcore.js"></script>
<script type="text/javascript" src="<%=basePath%>/sg/jqwidgets/jqxdata.js"></script>
<script type="text/javascript" src="<%=basePath%>/sg/jqwidgets/jqxbuttons.js"></script>
<script type="text/javascript" src="<%=basePath%>/sg/jqwidgets/jqxscrollbar.js"></script>
<script type="text/javascript" src="<%=basePath%>/sg/jqwidgets/jqxpanel.js"></script>
<script type="text/javascript" src="<%=basePath%>/sg/jqwidgets/jqxtree.js"></script>
2.html页面
<div class="tab-pane active" id="tab_1"> </div>
3.js代码
//部门树输出的div
var tree = $('#tab_1');
//一级部门数据
var source = null;
//下级部门数据
var source1 = null;
//首先请求一级部门数据
$.ajax({
type: "POST",
dataType : 'json',
url: app_base_path+"background/biz/selectDept.html",
data: {
"id":""//父id为空标示加载一部门数据
},
success :function(result) {
result = eval("("+result+")");
var data = result.result;
source =
{
datatype: "json",
datafields: [
{ name: 'c_id' },//部门id
{ name: 'c_pid' },//父级部门id
{ name: 'c_name' },//部门名称
{ name: 'value' }//此处写部门id就行
],
id: 'c_id',
localdata: data
};
//生成部门树
var dataAdapter = new $.jqx.dataAdapter(source);
dataAdapter.dataBind();
var records = dataAdapter.getRecordsHierarchy('c_id', 'c_pid', 'items', [{ name: 'c_name', map: 'label',icon: "<%=basePath%>/ dhtml/imgs/csh_bluebooks/folderClosed.gif"}]);
tree.jqxTree({ source: records, width: '400px', height: '420px'});
//当点击展开部门时执行以下代码(异步加载下级部门)
tree.on('expand', function (event) {
var label = tree.jqxTree('getItem', event.args.element).label;//
var $element = $(event.args.element);
var loader = false;
var loaderItem = null;
var children = $element.find('ul:first').children();//第一个下级部门(也就是如果有下级部门时默认加载一个名称为“查询中...”的虚拟下级部门)
//判断是否有下级部门名称为'查询中...'的
$.each(children, function () {
var item = tree.jqxTree('getItem', this);
if (item && item.label == '查询中...') {
loaderItem = item;
loader = true;
return false
};
});
//根据父级部门id查询子部门
if (loader) {
$.ajax({
type: "POST",
dataType : 'json',
url: app_base_path+"background/biz/selectDept.html",
data: {
"id":loaderItem.value//父级部门id
},
success :function(result) {
result = eval("("+result+")");
var data = result.result;
// prepare the data
source1 =
{
datatype: "json",
datafields: [
{ name: 'c_id' },
{ name: 'c_pid' },
{ name: 'c_name' },
{ name: 'value' }
],
id: 'c_id',
localdata: data
};
var dataAdapter = new $.jqx.dataAdapter(source1);
dataAdapter.dataBind();
var records1 = dataAdapter.getRecordsHierarchy('c_id', 'c_pid', 'items', [{ name: 'c_name', map: 'label',icon: "<%=basePath%>/dhtml/imgs/csh_bluebooks/folderClosed.gif"}]);
tree.jqxTree('addTo', records1, $element[0]);
tree.jqxTree('removeItem', loaderItem.element);
}
});
}
}); }
});
4.数据库语句(我用的是postgre数据库)
思路:a.首次查询父级部门id为null也就是一级部门,且如果有下级部门默认加载一个名称为"查询中..."的子部门
sql实现 直接查询pid = {#id}根据pid groub by 以下并且产生的一定为此部门的一个子部门再修改下字段就可以
例如:我写的这是包含人员表的 也就是部门下面的人也查出来了
select row_number() over()::character varying(30)||'' c_id,c_pid,'查询中...' c_name,c_pid value1 from (
select pt.c_id,pt.c_name,pt.c_pid,pt.c_id as value from db_sgtz.t_dept pt
union ALL
select c_id ,c_name ,c_dept as c_pid,c_id as value from db_sgtz.t_aty_user_zuig) a
where c_pid in(
select c_id from (
select pt.c_id,pt.c_name,pt.c_pid,pt.c_id as value from db_sgtz.t_dept pt
union ALL
select c_id ,c_name ,c_dept as c_pid,c_id as value from db_sgtz.t_aty_user_zuig) a
b.sql的难点就在与a如果明白a自然整条sql就好写了
全部sql
<select id="selectDept" parameterType="java.util.HashMap" resultType="Dept">
select c_id,c_pid,c_name,value from ( select c_id,c_pid,c_name,value from (
select pt.c_id,pt.c_name,pt.c_pid,pt.c_id as value from db_sgtz.t_dept pt
union ALL
select c_id ,c_name ,c_dept as c_pid,c_id as value from db_sgtz.t_aty_user_zuig) a
<if test="c_id == null or c_id == ''">
where c_pid is null
</if>
<if test="c_id != null and c_id != ''">
where c_pid = #{c_id}
</if>
union All
select row_number() over()::character varying(30)||'' c_id,c_pid,'查询中...' c_name,c_pid value1 from (
select pt.c_id,pt.c_name,pt.c_pid,pt.c_id as value from db_sgtz.t_dept pt
union ALL
select c_id ,c_name ,c_dept as c_pid,c_id as value from db_sgtz.t_aty_user_zuig) a where c_pid in(
select c_id from (
select pt.c_id,pt.c_name,pt.c_pid,pt.c_id as value from db_sgtz.t_dept pt
union ALL
select c_id ,c_name ,c_dept as c_pid,c_id as value from db_sgtz.t_aty_user_zuig) a <if test="c_id == null or c_id == ''">
where c_pid is null
</if>
<if test="c_id != null and c_id != ''">
where c_pid = #{c_id}
</if>
)
group by c_pid ) h
order by to_number(c_id,'')
</select>
5.效果图

jqxtree异步加载部门树的更多相关文章
- combotree -下拉框树异步加载
问题: 下拉树数据比较多时,全加载会产生页面延迟,需要实现异步加载 方案: 点击事件加载:先加载部分,点击节点时再展开并追加子节点 onBeforeExpand事件:在展开树前加载,感觉这种方式比较优 ...
- spring mvc easyui tree 异步加载树
使用spring mvc 注解 异步加载一棵树 jsp: <ul id="orgInfoTree"></ul> $(function(){ loadOrgT ...
- 玩转Web之easyui(二)-----easy ui 异步加载生成树节点(Tree),点击树生成tab(选项卡)
关于easy ui 异步加载生成树及点击树生成选项卡,这里直接给出代码,重点部分代码中均有注释 前台: $('#tree').tree({ url: '../servlet/School_Tree?i ...
- Jquery树控件ZTree异步加载
异步加载的意思就是: 当点击展开树节点时,才去请求后台action返回点击节点的子节点数据并加载. 这里面主要设计ztree的setting变量的async属性设置: var setting = { ...
- RDIFramework.NET ━ .NET快速信息化系统开发框架 V3.2->新增“行政区域管理”,同时大批量树采用异步加载
行政区划:简称政区,是国家为了进行分级管理而实行的区域划分.中国现行的行政区划实行如下原则:1.全国分为省.自治区.直辖市:2.省.自治区分为自治州.县.自治县.市:3.自治州分为县.自治县.市:4. ...
- ztree异步加载树节点
参考文档:https://www.cnblogs.com/tenWood/p/8620708.html ztree api地址:http://www.treejs.cn/v3/api.php 说明:j ...
- bootstrap异步加载树后样式显示问题
整个过程: 1.先加载整个页面 2.通过jquery异步请求后台返回数据 3.循环遍历数据,拼接需要的内容 4.把拼接好的数据加载到页面中. 问题: 把拼接好的内容加载到页面后,样式显示不正确.而如果 ...
- Jquery Ztree异步加载树
1. 下载jquery的JS文件/ztree的CSS文件和JS文件 https://jquery.com/download/ https://gitee.com/zTree/zTree_v3/tree ...
- zTree异步加载并初始化树时全部展开(贴主要代码)
<%@page pageEncoding="UTF-8"%> <%@include file="/commons/include/html_doctyp ...
随机推荐
- 如何使用fio模拟线上环境
线上表现 这里我想通过fio来模拟线上的IO场景,那么如何模拟呢? 首先使用iostat看线上某个盘的 使用情况,这里我们需要关注的是 avgrq-sz, avgrq-qz. #iostat -dx ...
- P1048 采药(洛谷,动态规划递推,01背包原题)
题目直接放链接 P1048 采药 这题只是01背包+背景故事而已 原题来的 PS:我写了一篇很详细的01背包说明,如果下面ac代码有看不懂的地方可以去看看 对01背包的分析与理解(图文) 下面上ac代 ...
- css3--伪元素和伪类
1,定义 W3C定义:伪元素伪类 都可以向某些选择器设置特殊效果.(css2中定义) css3中的定义: 1).伪元素:在DOM树中创建了一些抽象元素(虚拟的容器).由两个冒号::开头(css2中并没 ...
- PHP代码静态分析工具PHPStan
最近发现自己写的PHP代码运行结果总跟自己预想的不一样,排查时发现大多是语法错误,在运行之前错误已经种下.可能是自己粗心大意,或者说php -l检测太简单,不过的确是有一些语法错误埋藏得太深(毕竟PH ...
- BZOJ 3648 寝室管理
[题解] GDOI2016 Day2T3 如果给出的数据是一棵树那么皆大欢喜直接点分治就好了,用树状数组维护大于x的数的个数.如果是一棵基环树,我们先断掉环上的一条边,然后跑点分治:再加上经过这条边的 ...
- Delphi语法
类与对象 从用户角度考虑,用户并不需要了解面向对象编程的知识,就可编写Delphi应用程序.当用户在建立新窗体.添加新组件以及处理事件时,大部分相关代码会由Delphi自动产生.但是,知道语言及其细节 ...
- Ajax_数据格式_XML
[XML] 优点: --XML是一种通用的数据格式. --不必把数据强加到已经定义好的格式中,而是要为数据自定义合适的标记. --利用DOM可以完全掌控文档. 缺点: --如果文档来自于服务器,就必须 ...
- BNUOJ 13358 Binary Apple Tree
Binary Apple Tree Time Limit: 1000ms Memory Limit: 16384KB This problem will be judged on Ural. Orig ...
- How to automate PowerPoint using VB
Microsoft has an article that explains how to automate PowerPoint using VB For some odd reason they' ...
- [24点计算器][C++版本]无聊拿去玩
特性:数字数量.目标答案不限,当然数据大了会很慢... 基本可以去除所有本质相同的表达式...至少能等出结果的数据规模可以.. 安卓:http://yun.baidu.com/s/1slCGILn 程 ...