zTree的使用教程

1、首先去官网下载http://www.ztree.me/v3/main.php#_zTreeInfo

2、之后引入:

<script src="js/jquery.ztree.all-3.5.js"></script>
<link href="css/zTreeStyle/zTreeStyle.css" rel="stylesheet" type="text/css">

3、写js:

复制代码
<!--树形结构 JS-->
<script type="text/javascript">
    var setting= {
        data: {
            simpleData: {enable: true}
        },
        check: {
            enable: true,
            chkStyle: "radio",
            radioType: "all"
        },
        view: {
            showLine: true
        },
        callback: {
            onClick: onClick,
            onCheck: onCheck,
        }
    };

    var zNodes =[
            <#if selectNewsTypeAll?size gt 0>
                <#list selectNewsTypeAll as sNewsTypeAll>
                    {id:${sNewsTypeAll.id}, pId:${sNewsTypeAll.parentId}, name:"${sNewsTypeAll.name}"},
                </#list>
            </#if>
    ];

    $(document).ready(function() {
        $.fn.zTree.init($("#treeConfig"), setting, zNodes);
    });

    function onClick(e,treeId,treeNode) {
        var zTree = $.fn.zTree.getZTreeObj("treeConfig");
        zTree.checkNode(treeNode, !treeNode.checked, null, true);
        return false;
    }

    function onCheck(e,treeId,treeNode) {
        var zTree = $.fn.zTree.getZTreeObj("treeConfig"),
                nodes = zTree.getCheckedNodes(true);
        var name = "", id = "";
        for (var i = 0, l = nodes.length; i < l; i++) {
            name = nodes[i].name;
            newsTypeId = nodes[i].id;
        }
        $("#treeName").val(name);
        $("#treeId").val(id);
    }

    function showMenu() {
        var dropdownObj = $("#treeName");
        var dropdownOffset = $("#treeName").offset();
        $("#treeContainer").css({
            left: dropdownOffset.left + "px",
            top: dropdownOffset.top + dropdownObj.outerHeight() + "px"
        }).slideDown("fast");
        $("body").bind("mousedown", onBodyDown);
        var w = $("#treeName").width();
        var p = $("#treeName").css("padding-left");
        $("#treeConfig").css("width",parseInt(w)+parseInt(p)*2);
    }

    function hideMenu() {
        $("#treeContainer").fadeOut("fast");
        $("body").unbind("mousedown", onBodyDown);
    }

function onBodyDown(event) {
     if (!(event.target.id == "chooseButton" || event.target.id == "treeName" || event.target.id == "treeContainer" || $(event.target).parents("#treeContainer").length > 0)) {
            hideMenu();
            //以下代码暂时没用到 start
            var height = top.$("#mainFrame").contents().find("body").height();
            if (height < 850) {
                height = 850;
            }
            top.$("#mainFrame").height(height);
            //以下代码暂时没用到 end
        }
    }
</script>
复制代码

文本框的代码:

<input type="text" class="form-control input-sm" id="treeName" onclick="showMenu()">
<input type="hidden" name="newsTypeId" id="treeId"/>

树状图显示的地方:

<div id="treeContainer" class="treeContainer">
    <ul id="treeConfig" class="ztree"></ul>
</div>

必要的样式:

.treeContainer{
    display:none; 
    position: absolute;
}

以下是详解:

数据填充 
重点就在于zNodes的配置。就是要配置好id、pId、name;这三个属性。

复制代码
var zNodes =[
   <#if selectNewsTypeAll?size gt 0>
     <#list selectNewsTypeAll as sNewsTypeAll>
         {
         id:${sNewsTypeAll.id},
         pId:${sNewsTypeAll.parentId},
         name:"${sNewsTypeAll.name}"
         },
      </#list>
  </#if>
 ];
复制代码

setting 中callback是回调函数,我上面写了两个

callback: {
            //节点点击事件
            onClick: onClick, 
            //节点选中事件
            onCheck: onCheck,
}

setting中其他属性默认,就行。

由于一加载页面就要把树状图准备好,只不过没有显示出来而已!所以需要以下代码

$(document).ready(function() {
        //初始化
        $.fn.zTree.init($("#treeConfig"), setting, zNodes);
});

节点点击事件,没什么说的,这样配置就可以了:

function onClick(e,treeId,treeNode) {
        var zTree = $.fn.zTree.getZTreeObj("treeConfig");
        zTree.checkNode(treeNode, !treeNode.checked, null, true);
        return false;
}

节点选择事件:

复制代码
function onCheck(e,treeId,treeNode) {
        var zTree = $.fn.zTree.getZTreeObj("treeConfig"),
                nodes = zTree.getCheckedNodes(true);
        var name = "", id = "";
        for (var i = 0, l = nodes.length; i < l; i++) {
            name = nodes[i].name;
            newsTypeId = nodes[i].id;
        }
        $("#treeName").val(name);
        $("#treeId").val(id);
}
复制代码

其中:

 $("#treeName").val(name);
 $("#treeId").val(id);

是根据自己的业务来的,我是因为在选择节点之后,要把,你选择的名字显示出来,并且id要写入隐藏字段,以便保存到数据库。

树状图是在什么时候显示出来呢?我设置的是当点击文本框的时候显示出来

复制代码
function showMenu() {
        var dropdownObj = $("#treeName");
        var dropdownOffset = $("#treeName").offset();
        $("#treeContainer").css({
            left: dropdownOffset.left + "px",
            top: dropdownOffset.top + dropdownObj.outerHeight() + "px"
        }).slideDown("fast");
        $("body").bind("mousedown", onBodyDown);
        //获取文本框的宽度
        var w = $("#treeName").width();
        //获取文本框的内填充
        var p = $("#treeName").css("padding-left");
        //设置树状图的宽度
        $("#treeConfig").css("width",parseInt(w)+parseInt(p)*2);
}
复制代码

其中:

$("body").bind("mousedown", onBodyDown);

是绑定了一个鼠标点击事件,当点击其他区域,会触发onBodyDown事件。

复制代码
function onBodyDown(event) {
        if (!(event.target.id == "chooseButton" || event.target.id == "treeName" || event.target.id == "treeContainer" || $(event.target).parents("#treeContainer").length > 0)) {
            hideMenu();
            //以下代码暂时没用到 start
            var height = top.$("#mainFrame").contents().find("body").height();
            if (height < 850) {
                height = 850;
            }
            top.$("#mainFrame").height(height);
            //以下代码暂时没用到 end
        }
}
复制代码

这里面又调用hideMenu()把树状图隐藏掉。

需要用到的文本框代码:

<input type="text" class="form-control input-sm" id="treeName" onclick="showMenu()">
<input type="hidden" name="newsTypeId" id="treeId"/>

而用于显示树状图的代码是: 这段代码不一定要和上面那段文本框代码放在一起。

<div id="treeContainer" class="treeContainer">
   <ul id="treeConfig" class="ztree"></ul>
</div>

因为,这里面做了位置的偏移。

复制代码
function showMenu() {
        var dropdownObj = $("#treeName");
        //获取偏移量
        var dropdownOffset = $("#treeName").offset();
        $("#treeContainer").css({
            left: dropdownOffset.left + "px",
            top: dropdownOffset.top + dropdownObj.outerHeight() + "px"
        }).slideDown("fast");
        $("body").bind("mousedown", onBodyDown);
        var w = $("#treeName").width();
        var p = $("#treeName").css("padding-left");
        $("#treeConfig").css("width",parseInt(w)+parseInt(p)*2);
}
复制代码

由于zTree自带的样式不好看,我进行了细微的跳转,只是让显示稍微好看些

复制代码
/*一定要的*/
.treeContainer{
    display:none; 
    position: absolute;
}
/*根据自己情况而定*/
.treeContainer .ztree{
    background-color:#FFF;
}
复制代码
posted @   黄进广寒  阅读(5260)  评论(0编辑  收藏  举报
编辑推荐:
· 记一次.NET内存居高不下排查解决与启示
· 探究高空视频全景AR技术的实现原理
· 理解Rust引用及其生命周期标识(上)
· 浏览器原生「磁吸」效果!Anchor Positioning 锚点定位神器解析
· 没有源码,如何修改代码逻辑?
阅读排行:
· 分享4款.NET开源、免费、实用的商城系统
· 全程不用写代码,我用AI程序员写了一个飞机大战
· MongoDB 8.0这个新功能碉堡了,比商业数据库还牛
· 白话解读 Dapr 1.15:你的「微服务管家」又秀新绝活了
· 上周热点回顾(2.24-3.2)
点击右上角即可分享
微信分享提示