假装有需求

关于 jeecg 提供的部门树,相信很多小伙伴都已经用过了,今天假装有那么一个需求 "部门树弹窗选择默认展开下级部门",带着这个需求再次去探索一下吧。

一、改造之前的部门选择树流程

1.1 t:departSelect标签

代码片段:

<t:departSelect selectedNamesInputId="orgNames" selectedIdsInputId="orgIds"></t:departSelect>

关于 selectedNamesInputIdselectedIdsInputId 属性:

  • selectedNamesInputId:用于显示勾选后的部门名称
  • selectedIdsInputId:用于记录勾选后的部门id

使用 "t:departSelect" 标签其实帮我们创建了两个 inputorgNamesorgIds,就是上方指定的两个属性名称,效果如下:

<input class="inuptxt" readonly="true" type="text" id="orgNames" name="orgNames" style="width: 150px" onclick="openDepartmentSelect()">
<input class="inuptxt" id="orgIds" name="orgIds" type="hidden" value=",">

通过生成的这两个 input,我们发现重点落在了 openDepartmentSelect() 这个方法,下面来看一下这个方法。

1.2 openDepartmentSelect()方法

方法代码:

function openDepartmentSelect() {    
    $.dialog.setting.zIndex = 9999;     
    $.dialog({
        content: 'url:departController.do?departSelect', 
        zIndex: 2100, 
        title: '组织机构列表', 
        lock: true, 
        width: '400px', 
        height: '350px', 
        opacity: 0.4, 
        button: [       
        {name: '确定', callback: callbackDepartmentSelect, focus: true},       
        {name: '取消', callback: function (){}}   ]
    }).zindex();
}

知识点: jeecg 中所有的表单弹出采用的技术都是 lhgdialog ,技术链接:http://www.lhgdialog.com/

通过上方的请求链接,我们找到最终的跳转界面(departSelect.jsp):

1.3 departSelect.jsp界面

<html>
<head>
<title>组织机构集合</title>
···
<script type="text/javascript">
    ...
    /**加载展开方法**/
    function zTreeOnExpand(event, treeId, treeNode){
         var treeNodeId = treeNode.id;
         $.post(
            'departController.do?getDepartInfo',
            {parentid:treeNodeId,orgIds:$("#orgIds").val()},
            function(data){
                var d = $.parseJSON(data);
                if (d.success) {
                    var dbDate = eval(d.msg);
                    var tree = $.fn.zTree.getZTreeObj("departSelect");                     if (!treeNode.zAsync){
                        tree.addNodes(treeNode, dbDate);
                        treeNode.zAsync = true;
                    } else{
                        tree.reAsyncChildNodes(treeNode, "refresh");
                    }
                    /**tree.addNodes(treeNode, dbDate);**/
                }
            }
        );
    }     /**首次进入加载level为1的**/
    $(function(){
        $.post(
            'departController.do?getDepartInfo',
            {orgIds:$("#orgIds").val()},
            function(data){
                var d = $.parseJSON(data);
                if (d.success) {
                    var dbDate = eval(d.msg);
                    $.fn.zTree.init($("#departSelect"), setting, dbDate);
                }
            }
        );
    });
</script>
</head>
<body style="overflow-y: auto" scroll="no">
<input id="orgIds" name="orgIds" type="hidden" value="${orgIds}">
<ul id="departSelect" class="ztree" style="margin-top: 30px;"></ul>
</body>
</html>

知识点: jeecg 中所采用的树列表是 ztree ,技术链接:http://www.treejs.cn/

关于上方这两个方法的解读:
界面加载,首先请求数据,获取数据后初始化 ztree,每次部件被点击都会触发 zTreeOnExpand 方法,附带父部门 id 获取子部门数据。

通过该界面我们找到了最先请求数据的方法:getDepartInfo 方法,那么这个方法其实我们通过上方的注释已经了解到 首次进入加载level为1的,意味着只加载了父部门的数据,通过具体后台代码验证:

@RequestMapping(params = "getDepartInfo")
@ResponseBody
public AjaxJson getDepartInfo(HttpServletRequest request, HttpServletResponse response){     AjaxJson j = new AjaxJson();     String orgIds = request.getParameter("orgIds");     String[] ids = new String[]{}; 
    if(StringUtils.isNotBlank(orgIds)){
        orgIds = orgIds.substring(0, orgIds.length()-1);
        ids = orgIds.split("\\,");
    }     List<TSDepart> tSDeparts = new ArrayList<TSDepart>();     StringBuffer hql = new StringBuffer(" from TSDepart t where 1=1 ");
    tSDeparts = this.systemService.findHql(hql.toString());     List<Map<String,Object>> dateList = new ArrayList<Map<String,Object>>();
    if(tSDeparts.size()>0){
        Map<String,Object> map = null;
        String sql = null;
         Object[] params = null;
        for(TSDepart depart:tSDeparts){
            map = new HashMap<String,Object>();
            map.put("id", depart.getId());
            map.put("name", depart.getDepartname());             map.put("code",depart.getOrgCode());             if(ids.length>0){
                for(String id:ids){
                    if(id.equals(depart.getId())){
                        map.put("checked", true);
                    }
                }
            }             if(depart.getTSPDepart() != null){
                map.put("pId", depart.getTSPDepart().getId());
            }else{
                map.put("pId", "1");
            }             if(ids.length>0){
                for(String id:ids){
                    if(id.equals(depart.getId())){
                        map.put("checked", true);
                    }
                }
            }             dateList.add(map);
        }
    }
    net.sf.json.JSONArray jsonArray = net.sf.json.JSONArray.fromObject(dateList);
    j.setMsg(jsonArray.toString());
    return j;
}

果不其然,只加载了 orgType = 1 的结节。

至此,我们已经清楚地了解到具体改造步骤在于数据,接下来要开始改造了。

二、改造需求中的部门树

2.1 后台getDepartInfo方法

删除掉了 parentid 的判断条件

if(StringUtils.isNotBlank(parentid)){    
    TSDepart dePart = this.systemService.getEntity(TSDepart.class, parentid);
    hql.append(" and TSPDepart = ?");
    tSDeparts = this.systemService.findHql(hql.toString(), dePart);
} else {
    hql.append(" and t.orgType = ?");
    tSDeparts = this.systemService.findHql(hql.toString(), "1");
}

2.2 departSelect.jsp

$(function(){
    $.post(
        'departController.do?getDepartInfo',
        {orgIds:$("#orgIds").val()},
        function(data){
            var d = $.parseJSON(data);
            if (d.success) {
                var dbDate = eval(d.msg);
                $.fn.zTree.init($("#departSelect"), setting, dbDate);                 /**1、全部展开**/
                /**$.fn.zTree.init($("#departSelect"), setting, dbDate).expandAll(true);**/                 var treeObj = $.fn.zTree.getZTreeObj("departSelect");
                var nodes = treeObj.getNodes();                 /**设置节点展开**/
                for (var i= 0; i < nodes.length; i++) {
                    /**2、第二种方式实现全部展开**/
                    /**treeObj.expandNode(nodes[i], true, true, true);**/
                }                 /**3、只展开第一个节点**/
                treeObj.expandNode(nodes[0], true, true, true);
            }
        }
    );
});

效果图:

上方代码,提供了1、2、3,其中1、2都是事先全部展开节点,3表示展开指定的节点,具体用法请参考:http://www.treejs.cn/v3/api.php

三、试一试

既然我们了解到了ztee的使用,那么我们不防再完善一下这个部门选择,增加一个模糊搜索的功能,具体实现效果如下。

最后

文章作者:niceyoo
文章地址:https://www.cnblogs.com/niceyoo/p/10527254.html
如果觉得文章对你有所帮助,右下方点个推荐~

18年专科毕业后,期间一度迷茫,最近我创建了一个公众号用来记录自己的成长。


改造一下jeecg中的部门树的更多相关文章

  1. 如何将数据库中存的树转化为树形列表(以easyui的tree为例)

    很多时候,我们会把一棵树存放到数据库中,当前台需要展示一个树形列表时,将这棵树读取出来并显示,这个过程是怎么实现的呢? 这篇文章是以构造一棵easyui前台框架的一个树形列表为例,后台框架是sprin ...

  2. jqxtree异步加载部门树

    整体思路 A.要想实现异步加载第一次加载的是一级部门 B.加载一级部门,如果有子部门,部门前面带+号,没有子部门,部门前面没有+号(+号也就是点击可以展开) C.在sql中实现如果有子部门默认都加载一 ...

  3. lintcode :前序遍历和中序遍历树构造二叉树

    解题 前序遍历和中序遍历树构造二叉树 根据前序遍历和中序遍历树构造二叉树. 样例 给出中序遍历:[1,2,3]和前序遍历:[2,1,3]. 返回如下的树: 2 / \ 1 3 注意 你可以假设树中不存 ...

  4. WPF中的逻辑树和可视化树

    WPF中的逻辑树是指XAML元素级别的嵌套关系,逻辑树中的节点对应着XAML中的元素. 为了方便地自定义控件模板,WPF在逻辑树的基础上进一步细化,形成了一个“可视化树(Visual Tree)”,树 ...

  5. LintCode-73.前序遍历和中序遍历树构造二叉树

    前序遍历和中序遍历树构造二叉树 根据前序遍历和中序遍历树构造二叉树. 注意事项 你可以假设树中不存在相同数值的节点 样例 给出中序遍历:[1,2,3]和前序遍历:[2,1,3]. 返回如下的树:    ...

  6. SQL 由人员汇总到部门树递归合计总数函数

    1.由人员计算出总数,在部门树(tree)按结构汇总(主父绑定) CREATE function [dbo].[GetEmpDepNum] ( @ID int ) RETURNS @Tree Tabl ...

  7. 利用树的先序和后序遍历打印 os 中的目录树

    [0]README 0.1)本代码均为原创,旨在将树的遍历应用一下下以加深印象而已:(回答了学习树的遍历到底有什么用的问题?)你对比下linux 中的文件树 和我的打印结果就明理了: 0.2)我们采用 ...

  8. JEECG中修改时间相关自定义定时器

    JEECG中使用,如下: @InitBinder public void initBinder(ServletRequestDataBinder binder) { binder.registerCu ...

  9. jeecg中dictSelect取值方式

    jeecg中的dictSelect本质是生成了很多input标签和div标签组成的,input存储的对应的就是字典中的code,div存储的就是字典中的name, 下面是取出code和那么的实例: 例 ...

随机推荐

  1. storage和memory

    memory:使用的是值传递,默认使用的是memory,传递的是值 storage:引用传递,传过来的是指针,后面一定要加上internal,private pragma solidity ^; co ...

  2. 字符串(3)AC自动机

    AC自动机真神奇,其实说白了就是在trie树上进行kmp模式匹配,不过刚接触确实有些难度,有些思想确实有些难以理解,所以学习的时候最好亲自手动模拟整个算法的全过程,那我就来写篇blog总结一下. 首先 ...

  3. git命令之git remote的用法

    git remote git  remote -v git init git add xxx git commit -m 'xxx' git remote add origin ssh://softw ...

  4. C#学习-接口

    众所周知,电脑有拍照和播放光碟的功能. 现在有一个TakingPhoto类,它提供了拍照的功能:还有一个PlayVCD类,它提供了播放光碟的功能. 电脑同时具有着两个类提供的功能,因此我们希望定义一个 ...

  5. arraylist 为什么 删除元素时要使用迭代器而不能使用遍历

    因为你要是遍历了,arraylist 的长度就变了,容易数组越界和下标问题 public class Test {     public static void main(String[] args) ...

  6. leetcode刷题第二天<两数相加>

    题目描述 给出两个 非空 的链表用来表示两个非负的整数.其中,它们各自的位数是按照 逆序 的方式存储的,并且它们的每个节点只能存储 一位 数字. 如果,我们将这两个数相加起来,则会返回一个新的链表来表 ...

  7. C - 树的统计Count - 树链剖分

    思路 :树剖模板,线段树维护即可. #include<bits/stdc++.h> using namespace std; #define MID int m = (l+r)/2 #de ...

  8. 在iphone的safari浏览器中,拨打电话,出现系统异常弹框

    这是系统级别的问题,暂时无法解决. IPHONE的safari浏览器电话拨打,前两次点击拨打按钮,会正常弹出系统弹框包含(电话号码,取消,呼叫). 第3次往后,点击按钮会出现另一种系统弹框包含(已阻止 ...

  9. linux中python3安装和使用

    python安装 下载python安装包和依赖环境 #自由选择python3源码包的版本https://www.python.org/ftp/python/https://www.python.org ...

  10. 在VS2010上安装MVC4(webApi)

    我们安装的VS2010上是没有MVC4或者WebApi的,要想加入这些功能只能自己在网上下载安装. 要安装MVC4,首先得安装VS10sp(Service Package)1,然后再安装MVC4.安装 ...