0

0

jQuery中zTree树插件使用分享

黄舟

黄舟

发布时间:2017-09-25 09:58:50

|

2644人浏览过

|

来源于php中文网

原创

分享说明:

  项目需要树状视图形式展示后台返回的数据;并实现点击节点将节点信息添加到右侧的ul中;待后续提交获取使用;选择了能够实现异步加载节点信息的zTree插件,事实也证明这个插件足够强大,能够满足几乎所有需求;刚接触时看了很多人的分享,结合官方api文档,终于实现了功能,现将我学习的总结也分享出去.

  效果介绍;除了zTree默认的效果;使用api增加了一些实用的操作;包括手风琴效果;点击父节点展开效果;点击节点文字关联复选框效果;一级子节点数量展示效果.

  外部引入资源

1     
2     
3     

  html部分代码

    • 已选择

      css代码

    ul,li,body{
            margin: 0;
            padding: 0;
        }
        .ztree li span.node_name {
            font-size: 16px;
        }
        .box{
            width: 500px;
            margin:10px auto;
            border:3px solid #ccc;
            padding: 20px;
            border-bottom: none;
        }
        #treeDemo{
            width: 200px;
            display: inline-block;
            background-color: #f1f1f1;
            min-height: 200px;
        }
        #ulright{
            width: 200px;
            margin-left: 50px;
            min-height: 200px;
            border:1px solid #ccc;
            display: inline-block;
            vertical-align: top;
            background-color: #eeeee8;
        }
        #ulright li{
            width: 100%;
            height: 30px;
            list-style: none;
            line-height: 30px;
            margin-bottom: 3px;
            background-color: #00b6ba;
            padding-left: 10px;
            box-sizing: border-box;
    
        }
    
    
        /**/
        .ztree li a.curSelectedNode{
            background-color: transparent;
            border:#00b6ba;
        }
        .ztree li span.node_name{
            font-size: 18px;
            line-height: 18px;
            color: #000;
        }
        .ztree li a{
           padding: 5px;
           vertical-align: middle;
        }
        .ztree li a:hover{
            text-decoration: none;
        }
        .ztree li span.button.chk{
            margin: 9px 3px;
        }

      js代码

    Gridster.js多列网格式拖动布局插件
    Gridster.js多列网格式拖动布局插件

    网页中拖动 DIV 是很常见的操作,今天就分享给大家一个 jQuery 多列网格拖动布局插件,和其它的插件不太一样的地方在于你处理拖放的元素支持不同大小,并且支持多列的网格布局,它们会自动的根据位置自己排序和调整。非常适合你开发具有创意的应用。这个插件可以帮助你将任何的 HTML 元素转换为网格组件

    下载
    //递归找到所有节点(非父节点)
    function getAllChildrenNodes(treeNode,result){
          if (treeNode.isParent) {
            var childrenNodes = treeNode.children;
            if (childrenNodes) {
                for (var i = 0; i < childrenNodes.length; i++) {
                    if(!childrenNodes[i].children){
                        result.push(childrenNodes[i].name);
                    }
                    result = getAllChildrenNodes(childrenNodes[i], result);
                }
            }
        }
        return result;
    }
    var parames = 3;
    //zTree的所有配置
    var setting = {
        //zTree 的唯一标识,初始化后,等于 用户定义的 zTree 容器的 id 属性值。
        treeId:"",
        //zTree 容器的 jQuery 对象,主要功能:便于操作,内部参数,不可修改
        treeObj:null,
        //异步请求数据配置;当父节点没有子节点时;点击此父节点会触发请求
        async:{
            //打开此功能
            enable: true,
            url:"./zTreeDemoV9.0SimpleFromV10.0.php",
            type:"post",
            //发送的父级id的字段定义;如修改,遵循格式autoParam: ["id=parentId"]
            autoParam: ["id"],
            //其他需要提交的参数["name","topic","key","ss"]转换后格式为name=topic&key=ss
            otherParam:["json",parames || 1,"test","2"],
            dataType:"json",
            contentType: "application/x-www-form-urlencoded",
            //ajax请求后的数据预处理函数
            dataFilter: function(treeId,parentNode,responseData){
                for(var i=0;i("+count+")");
            },
            //父节点展开时的事件
            onExpand: function(event, treeId, treeNode){
                //zTree对象
                var zTree = $.fn.zTree.getZTreeObj("treeDemo");
                //获取点击的id
                var nowId = treeNode.id;
                //获取所有节点
                var allNodes = zTree.getNodes();
                //获取点击节点的层级
                var level = treeNode.level;
                //定义过滤函数;获取节点层级与点击节点层级相同并且为父节点的节点
                function filter(node) {
                    return (node.level == treeNode.level && node.isParent);
                }
                //获得点击节点同级的父节点的集合
                var sameLevelNodes = zTree.getNodesByFilter(filter);
                //遍历同级节点集合
                for(var i=0;i");
                        addLi.find("span").text(treeNode.name);
                        addLi.animate({
                            width:"100%",
                            height:"30"
                        },400)
                        addLi.appendTo($("#ulright"));
                        //如果点击的节点存在connect字段;判断复选框状态加入到右侧ul或删除
                        if(treeNode.connect){
                            //遍历右侧li,如果选中的已经存在;return
                            for(var i=0;i");
                                addLi.find("span").text(treeNode.connect);
                                addLi.animate({
                                    width:"100%",
                                    height:"30"
                                },400)
                            addLi.appendTo($("#ulright"));
                        }
                        //将被勾选的节点背景颜色更改
                        $("#treeDemo").find("a[title="+treeNode.name+"]").css("backgroundColor","#00b6ba");
                    //非选中状态,删除
                    }else{
                        //将右侧的次节点对应的li删除
                        $("#ulright").find("li[title="+treeNode.name+"]").animate({
                            width:"0%",
                            height:"0"
                        },400,function(){
                            $("#ulright").find("li[title="+treeNode.name+"]").remove();
                        })
                        //取消此节点的背景颜色
                       $("#treeDemo").find("a[title="+treeNode.name+"]").css("backgroundColor","");
                    }
                //选中的是父节点;获取所有子节点(非父节点),判断复选框状态加入到右侧ul或删除
                }else{
                    //调用递归函数;获取所有非父级子节点数组集合
                    var addNodesArray = getAllChildrenNodes(treeNode,[]);
                    //是选中状态,加入到右侧ul
                    if(treeNode.checked){
                        //定义存储右侧li的数组
                        var rightLiArray = [];
                        $("#ulright li").each(function(i,v){
                            rightLiArray.push($(v).attr("title"))
                        })
                        rightLiArray = rightLiArray.slice(1);
                        //遍历勾选的数组集合
                        for(var i=0;i"+addNodesArray[i]+"");
                                addLi.animate({
                                    width:"100%",
                                    height:30
                                },400)
                                addLi.appendTo($("#ulright"));
                            }
                            //将节点背景颜色修改
                            $("#treeDemo").find("a[title="+addNodesArray[i]+"]").css("backgroundColor","#00b6ba");
                        }
                    //是非选中状态,删除
                    }else{
                        //遍历节点,执行删除操作
                        for(var i=0;i

      后台php代码;本人纯前端,后台代码只会简单的写写;

    js代码大部分都有注释;详细api可在zTree官网查看 进入官方api文档  代码运行需在服务器环境下运行;

    最终栗子效果图

    热门AI工具

    更多
    DeepSeek
    DeepSeek

    幻方量化公司旗下的开源大模型平台

    豆包大模型
    豆包大模型

    字节跳动自主研发的一系列大型语言模型

    通义千问
    通义千问

    阿里巴巴推出的全能AI助手

    腾讯元宝
    腾讯元宝

    腾讯混元平台推出的AI助手

    文心一言
    文心一言

    文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

    讯飞写作
    讯飞写作

    基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

    即梦AI
    即梦AI

    一站式AI创作平台,免费AI图片和视频生成。

    ChatGPT
    ChatGPT

    最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

    相关专题

    更多
    俄罗斯Yandex引擎入口
    俄罗斯Yandex引擎入口

    2026年俄罗斯Yandex搜索引擎最新入口汇总,涵盖免登录、多语言支持、无广告视频播放及本地化服务等核心功能。阅读专题下面的文章了解更多详细内容。

    178

    2026.01.28

    包子漫画在线官方入口大全
    包子漫画在线官方入口大全

    本合集汇总了包子漫画2026最新官方在线观看入口,涵盖备用域名、正版无广告链接及多端适配地址,助你畅享12700+高清漫画资源。阅读专题下面的文章了解更多详细内容。

    35

    2026.01.28

    ao3中文版官网地址大全
    ao3中文版官网地址大全

    AO3最新中文版官网入口合集,汇总2026年主站及国内优化镜像链接,支持简体中文界面、无广告阅读与多设备同步。阅读专题下面的文章了解更多详细内容。

    79

    2026.01.28

    php怎么写接口教程
    php怎么写接口教程

    本合集涵盖PHP接口开发基础、RESTful API设计、数据交互与安全处理等实用教程,助你快速掌握PHP接口编写技巧。阅读专题下面的文章了解更多详细内容。

    2

    2026.01.28

    php中文乱码如何解决
    php中文乱码如何解决

    本文整理了php中文乱码如何解决及解决方法,阅读节专题下面的文章了解更多详细内容。

    4

    2026.01.28

    Java 消息队列与异步架构实战
    Java 消息队列与异步架构实战

    本专题系统讲解 Java 在消息队列与异步系统架构中的核心应用,涵盖消息队列基本原理、Kafka 与 RabbitMQ 的使用场景对比、生产者与消费者模型、消息可靠性与顺序性保障、重复消费与幂等处理,以及在高并发系统中的异步解耦设计。通过实战案例,帮助学习者掌握 使用 Java 构建高吞吐、高可靠异步消息系统的完整思路。

    8

    2026.01.28

    Python 自然语言处理(NLP)基础与实战
    Python 自然语言处理(NLP)基础与实战

    本专题系统讲解 Python 在自然语言处理(NLP)领域的基础方法与实战应用,涵盖文本预处理(分词、去停用词)、词性标注、命名实体识别、关键词提取、情感分析,以及常用 NLP 库(NLTK、spaCy)的核心用法。通过真实文本案例,帮助学习者掌握 使用 Python 进行文本分析与语言数据处理的完整流程,适用于内容分析、舆情监测与智能文本应用场景。

    24

    2026.01.27

    拼多多赚钱的5种方法 拼多多赚钱的5种方法
    拼多多赚钱的5种方法 拼多多赚钱的5种方法

    在拼多多上赚钱主要可以通过无货源模式一件代发、精细化运营特色店铺、参与官方高流量活动、利用拼团机制社交裂变,以及成为多多进宝推广员这5种方法实现。核心策略在于通过低成本、高效率的供应链管理与营销,利用平台社交电商红利实现盈利。

    122

    2026.01.26

    edge浏览器怎样设置主页 edge浏览器自定义设置教程
    edge浏览器怎样设置主页 edge浏览器自定义设置教程

    在Edge浏览器中设置主页,请依次点击右上角“...”图标 > 设置 > 开始、主页和新建标签页。在“Microsoft Edge 启动时”选择“打开以下页面”,点击“添加新页面”并输入网址。若要使用主页按钮,需在“外观”设置中开启“显示主页按钮”并设定网址。

    72

    2026.01.26

    热门下载

    更多
    网站特效
    /
    网站源码
    /
    网站素材
    /
    前端模板

    精品课程

    更多
    相关推荐
    /
    热门推荐
    /
    最新课程
    jQuery 教程
    jQuery 教程

    共42课时 | 5万人学习

    HTML+CSS基础与实战
    HTML+CSS基础与实战

    共132课时 | 9.8万人学习

    tp6+adminlte搭建通用后台
    tp6+adminlte搭建通用后台

    共39课时 | 5.8万人学习

    关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
    php中文网:公益在线php培训,帮助PHP学习者快速成长!
    关注服务号 技术交流群
    PHP中文网订阅号
    每天精选资源文章推送

    Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号