【zTree】zTree根据后台数据生成树并动态设置前面的节点复选框的选中状态

【zTree】zTree根据后台数据生成树并动态设置前面的节点复选框的选中状态

大家好,又见面了,我是全栈君。

 

0.页面中准备树的ul

<ul id="treeDemo10" class="ztree" style="display: none;"></ul>

 1.生成部门树的JS

// 查询外部部门结构
var searchUnitTree = function() {
    $.ajax({
        url : contextPath + '/exam_getUnitTree.action',
        async : true,
        dataType : 'json',
        success : function(response) {
            zNodes11 = response.unitTrees;
            // 生成树结构
            geneUnitTree(zNodes11);

        },
        error : function() {
            alert("查询外部部门树失败!!!")
        }
    });
}

// 生成外部部门树
function geneUnitTree(unitTrees) {
    $("#treeDemo10").html(""); // 清空树结构
    var setting = {
        view : {
            selectedMulti : false
        },
        check : {
            enable : true
        },
        data : {
            simpleData : {
                enable : true,
                idKey : "unitId",
                pIdKey : "upUnitId",
                rootPId : null
            },
            key : {
                name : "name",
            }
        },
        callback : {
            beforeCheck : beforeCheck_out,
            onClick : zTreeOnClick_out
        }
    };
    var treeNodes11 = unitTrees;
    $.fn.zTree.init($("#treeDemo10"), setting, treeNodes11);
}
// 鼠标点击树事件(打印点击的id与名字)
function zTreeOnClick_out(event, treeId, treeNode) {
    // alert(treeNode.unitId + ", " + treeNode.name);
    alert($("#el_chooseDepart1").text());

}
// 点击前面的复选框事件
function beforeCheck_out(treeId, treeNode) {
    className10 = (className10 === "dark" ? "" : "dark");
    el_id = treeNode.name;
    // 判断点击的节点是否被选中,返回false 和 true
    if (!treeNode.checked) {
   
   // 选中
        showLog10_out(treeNode.name + ',');// 加上逗号加以区分
        $("#department_employee_out")
                .append(
                        // 添加部门到下面的选择员工
                        '<div class="panel panel-default el_departPersons" id="'
                                + treeNode.name
                                + '">'
                                + '<div class="panel-heading"><span class="el_addDepart" >'
                                + treeNode.name
                                + '</span>&nbsp;&nbsp;'
                                + '(人数:<span class="employeeNum">0</span>)</div>'
                                + '<div class="panel-body"></div>' + '</div>');
    } else { // 点击选中,向让其未选中
        noshowLog10_out(treeNode.name + ',', treeNode);
        $("#" + treeNode.name).remove();// 反选复选框删除部门
        var parentzTree = treeNode.getParentNode();
    }
    return (treeNode.doCheck !== false);
}
function showLog10_out(str) {
    if (!el_chooseDepart1)
        el_chooseDepart1 = $("#el_chooseDepart1");
    el_chooseDepart1.append("<li class='" + className10 + "' id='" + el_id
            + "'>" + str + "</li>");

    if (el_chooseDepart1.children("li").length > 6) {
        el_chooseDepart1.get(0).removeChild(el_chooseDepart1.children("li")[0]);
    }
}

function noshowLog10_out(str, tNode) {
    if (!el_chooseDepart1)
        el_chooseDepart1 = $("#el_chooseDepart1");
    // 删除当前选中的树的名字
    el_chooseDepart1.children("#" + el_id).remove();
    // 删除当前子的树的名字
    if (tNode.isParent) {
        var childrenNodes = tNode.children;
        if (childrenNodes) {
            for (var i = 0; i < childrenNodes.length; i++) {
                alert();
                var el_id0 = childrenNodes.name;
                el_chooseDepart1.children("#" + el_id0).remove();

                // result += ',' + childrenNodes[i].id;
                // result = getChildNodes(childrenNodes[i], result);
            }
        }
    }

}

 

后台返回的JSON数据格式:

{"unitTrees":[{"name":"部门1","unitId":"1"},{"upUnitId":"1","name":"部门10001","unitId":"10001"},{"upUnitId"
:"10001","name":"部门100010001","unitId":"100010001"},{"upUnitId":"1","name":"部门10002","unitId":"10002"
},{
    
    "upUnitId":"10002","name":"部门100020001","unitId":"100020001"},{"upUnitId":"1","name":"部门10003","unitId"
:"10003"}]}

 

生成的树结构: 

【zTree】zTree根据后台数据生成树并动态设置前面的节点复选框的选中状态

 

 

 2.根据树的name属性动态设置前面的复选框为选中(根据树节点的名字判断,也可以根据其他属性判断)

  // 获取树对象
    var treeObj = $.fn.zTree.getZTreeObj("treeDemo10");
    /** 获取所有树节点 */
    var nodes = treeObj.transformToArray(treeObj.getNodes());
        // 遍历树节点设置树节点为选中
        for (var k = 0, length_3 = nodes.length; k < length_3; k++) {
            if (unitName[j] == nodes[k].name) {
                nodes[k].checked = true;
          treeObj.updateNode(nodes[k],true); } }

 

补充:设置checked属性之后,一定要更新该节点,否则会出现只有鼠标滑过的时候节点才被选中的情况

    // 获取树对象
    var treeObj = $.fn.zTree.getZTreeObj("treeDemo");
    /** 获取所有树节点 */
    var nodes = treeObj.transformToArray(treeObj.getNodes());
    // 遍历树节点设置树节点为未选中
    for (var k = 0, length_3 = nodes.length; k < length_3; k++) {
        nodes[k].checked = false;
       treeObj.updateNode(nodes[k],true);
    }

 

查看updateNode方法解释:(也就是更新的时候需要安装自己定义的上级与下级关联关系进行更新)

【zTree】zTree根据后台数据生成树并动态设置前面的节点复选框的选中状态

 

 

 

 

 js中debugger查看nodes(JS数组):

【zTree】zTree根据后台数据生成树并动态设置前面的节点复选框的选中状态

 

查看第一个节点:(有好多属性)

【zTree】zTree根据后台数据生成树并动态设置前面的节点复选框的选中状态

 

 

效果:

【zTree】zTree根据后台数据生成树并动态设置前面的节点复选框的选中状态

 

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/108075.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • linux查看权限命令

    linux查看权限命令查看权限命令查看目录的相关权限可以采用命令ls-lD,或者直接用ls-la如ls-lwwwt//这里表示查看www目录修改权限命令chmod777文件名1.chmod577/home/stuser-R2.umask-p02003.chownXXXXYYYY(XXXX为用户名YYYY为文件名)权限列表-rw——-(600)只有所有者才…

    2022年5月15日
    66
  • Ant安装配置

    Ant安装配置先在http://ant.apache.org/下载Ant,例如我下载的是最新版的apache-ant-1.7.1-bin.zip文件,然后解压缩至E:/apache-ant-1.7.1,添加环境变量ANT_HOME=E:/apache-ant-1.7.1,在PATH变量中添加%ANT_HOME%/bin;,Ant就算是配置好了。环境:WindowsXP

    2022年7月18日
    13
  • typescript的泛型_typescript declare

    typescript的泛型_typescript declare泛型指在定义函数、接口或类的时候,不预先指定具体的类型,而在使用的时候再指定具体类型的一种特性。引入下面创建一个函数,实现功能:根据指定的数量count和数据value,创建一个包

    2022年8月7日
    1
  • windows server 2008 web服务器搭建

    windows server 2008 web服务器搭建在众多小企业中,Web服务器的应用也需是最广泛的,企业网站的建立促进了服务器进驻中小企业,而Web服务器的建立也越来越多。而面对诸多的Web服务器应用系统,可以说是多种多样,有大家最熟悉的微软的IIS,也有开源的Apache,还有大型网站应用比较多的Unix,总之可以说是各有各的优点。  今天介绍的是,微软的IIS,因其图形界面的操作方式,给人以直观的操作感受,部署简便,是很多用户的首选,而Apache的部署要相对复杂,一般新手很难马上上手,所以这里先跟大家讲解一下IIS7.0的搭建Web服务器的方法。

    2022年5月28日
    38
  • 品优购-day03笔记-完善品优购的首页&制作列表页「建议收藏」

    品优购-day03笔记-完善品优购的首页&制作列表页「建议收藏」typora-copy-images-to:media第01阶段.WEB基础:品优购-day03笔记-完善品优购的首页&制作列表页学习目标完善品优购项目的首页index.html制作品优购项目的列表页list.html品优购项目(三)第01阶段.WEB基础:品优购-day02笔记-品优购首页1.品优购首页布局命名集合:名称说明…

    2022年5月8日
    58
  • C语言实现PID算法:位置式PID和增量式PID[通俗易懂]

    原创者微信公众号PID算法可以说是在自动控制原理中比较经典的一套算法,在现实生活中应用的比较广泛。大学参加过电子竞赛的朋友都应该玩过电机(或者说循迹小车),我们要控制电机按照设定的速度运转,PID控制在其中起到了关键的作用。说来惭愧,大学这门课程学的不咋滴,老师讲的课基本没听进去过。直到后面接触竞赛,算是对PID有了很基础的一点点认识,直到现在工作实际应用的…

    2022年4月11日
    111

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号