0

0

实例讲解jQuery使用zTree插件实现可拖拽功能

小云云

小云云

发布时间:2017-12-27 10:45:49

|

2209人浏览过

|

来源于php中文网

原创

在目前接触到的树插件中,我觉得ztree比较简单,也容易上手。有一次业务需求是将某对象分组树上的对象可以随意拖拽,相当于改变了对象的分组,因此我用到了ztree,对其进行了一些列学习。本文主要介绍了js使用ztree插件实现可拖拽的树示例,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧,希望能帮助到大家。

 首先下载zTree所需的相关包,附上官方下载连接:zTree下载,引入相关文件后就可以进行zTree的构建了。首先在页面上加ul标签,然后为树加上id,calss为ztree,前端页面就完成了。

注意:下面所有的代码是根据我自己的需求写的,且不完整,主要参考配置流程和回调函数的使用即可。

前端页面:


 

    然后写JavaScript,写之前一定要多多阅读zTree的官方API,上面已经解释的很详细了,只需要照着一步一步做即可。首先就是配置setting,这个是整个zTree的核心配置,我这里除了基本配置外,因为需要拖拽功能,因此配置了edit,其中enable一定要设为true,其他参数看需求配置。callback中也配置相关的回调函数。

     setting配置:


     var setting = {
     data: {
      key:{
       name:'nodeName'
      },
      simpleData: {
       enable: true,
       idKey: 'nodeId',
       pIdKey: 'parentNodeId'
      },
      keep:{
       leaf:true,
       parent:true,
      }
     },
     edit:{
      drag:{
       isCopy: false,
       isMove: true,
       prev: true,
       next: true,
       inner: true,
       autoOpenTime: 0,
       minMoveSize: 10
    
    
      },
      enable:true,
      editNameSelectAll: true,
      removeTitle: "删除节点",
      renameTitle: "编辑节点名称",
      showRemoveBtn: false,
      showRenameBtn: false,
     },
    
     callback: {
      beforeClick: beforeClick,
    
      beforeDrag:beforeDrag,
      beforeDragOpen:beforeDragOpen,
      beforeDrop:beforeDrop,
      onDrag:onDr},
    };

     配置完setting,将各个回调函数补充完整,根据需求来定里面的内容,我这里根据父节点的类型以及一些其他一些规则对能否拖拽,拖拽能否成功进行了相应的限制。

     回调函数:

    Delphi 7应用编程150例 全书内容 CHM版
    Delphi 7应用编程150例 全书内容 CHM版

    Delphi 7应用编程150例 CHM全书内容下载,全书主要通过150个实例,全面、深入地介绍了用Delphi 7开发应用程序的常用方法和技巧,主要讲解了用Delphi 7进行界面效果处理、图像处理、图形与多媒体开发、系统功能控制、文件处理、网络与数据库开发,以及组件应用等内容。这些实例简单实用、典型性强、功能突出,很多实例使用的技术稍加扩展可以解决同类问题。使用本书最好的方法是通过学习掌握实例中的技术或技巧,然后使用这些技术尝试实现更复杂的功能并应用到更多方面。本书主要针对具有一定Delphi基础知识

    下载


     //拖拽之前调用的函数
    function beforeDrag(treeId,treeNode){
     if(treeNode[0].nodeType == 'GROUP'){
      return false;
     }
     if(treeNode.parentId == null && treeNode.modelType !=null){
      return true;
     }
     var node = treeNode[0].getParentNode();
     var modelType = treeNode[0].getParentNode().modelType;
     if(modelType == 'INTERFACE'){
      return false;
     }else {
      return true;
     }
    }
    
    //预留被拖拽的回调函数
    function onDrag(event, treeId, treeNode){
     //暂时没用到
    }
    
    //拖拽移动到展开父节点之前调用的函数
    function beforeDragOpen(){
     return true;
    }
    
    //拖拽操作结束之前调用的函数
    function beforeDrop(treeId, treeNode, targetNode, moveType){
     BRS.fileLoading('show');
     var result = false;
     if(targetNode == null || (moveType != "inner" && !targetNode.parentTId)){
      BRS.fileLoading('hide');
      return false;
     }
     if(targetNode.modelType != null){
      if((targetNode.modelType == 'INTERFACE' && moveType == 'inner') || targetNode.getParentNode().modelType == 'INTERFACE'){
       BRS.fileLoading('hide');
       return false;
      }
     }
     var objDetail = {
      url: '/api/model/' + treeNode[0].id,
      async:false,
     }
     jsonAjax(objDetail,function (detailData) {
      var data = {
       nodeType : detailData.nodeType,
       code : detailData.code,
       name : detailData.name,
       builtIn : detailData.builtIn,
       iconUrl : detailData.iconUrl,
       modelType : detailData.modelType.code,
       interfaceModelId : detailData.interfaceModelId,
      };
      data.id = treeNode[0].id;
      if(moveType != 'inner'){
       data.groupId = targetNode.parentId;
      }else{
       data.groupId = targetNode.id;
      }
      var obj = {
       type:"put",
       showSuccessMsg: false,
       param: {
        params:JSON.stringify(data)
       },
       async:false,
       url: '/api/model',
      }
      jsonAjax(obj,function(updateData){
       if(updateData != null){
        result = true;
      ing('hide');
     return result;
    }
    
    //预留拖拽结束的回调函数
    function onDrop(event, treeId, treeNode, targetNode, moveType){
     befod('hide');
     return result;
    }
    
    //预留拖拽结束的回调函数
    function onDrop(event, treeId, treeNode, targetNode, moveType){
     beforeClick(treeId, treeNode[0]);
    }

    上面的设置和相关函数完成以后,就可以调用zTree的初始化方法,通过Ajax请求回来的参数去填充我们所需要的树了。


    // 初始化对象分组树
     var treeObj = $("#modelTree");
     $.fn.zTree.init(treeObj, setting, data);
     zTree_Menu = $.fn.zTree.getZTreeObj("modelTree");

    最后形成的树(可以拖拽的):

     

    相关推荐;

    zTree插件之多选下拉菜单实例代码_javascript技巧

    jQuery使用zTree插件实现树形菜单和异步加载_jquery

    zTree插件下拉树使用入门教程_javascript技巧

    热门AI工具

    更多
    DeepSeek
    DeepSeek

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

    豆包大模型
    豆包大模型

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

    通义千问
    通义千问

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

    腾讯元宝
    腾讯元宝

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

    文心一言
    文心一言

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

    讯飞写作
    讯飞写作

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

    即梦AI
    即梦AI

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

    ChatGPT
    ChatGPT

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

    相关专题

    更多
    AO3官网入口与中文阅读设置 AO3网页版使用与访问
    AO3官网入口与中文阅读设置 AO3网页版使用与访问

    本专题围绕 Archive of Our Own(AO3)官网入口展开,系统整理 AO3 最新可用官网地址、网页版访问方式、正确打开链接的方法,并详细讲解 AO3 中文界面设置、阅读语言切换及基础使用流程,帮助用户稳定访问 AO3 官网,高效完成中文阅读与作品浏览。

    60

    2026.02.02

    主流快递单号查询入口 实时物流进度一站式追踪专题
    主流快递单号查询入口 实时物流进度一站式追踪专题

    本专题聚合极兔快递、京东快递、中通快递、圆通快递、韵达快递等主流物流平台的单号查询与运单追踪内容,重点解决单号查询、手机号查物流、官网入口直达、包裹进度实时追踪等高频问题,帮助用户快速获取最新物流状态,提升查件效率与使用体验。

    21

    2026.02.02

    Golang WebAssembly(WASM)开发入门
    Golang WebAssembly(WASM)开发入门

    本专题系统讲解 Golang 在 WebAssembly(WASM)开发中的实践方法,涵盖 WASM 基础原理、Go 编译到 WASM 的流程、与 JavaScript 的交互方式、性能与体积优化,以及典型应用场景(如前端计算、跨平台模块)。帮助开发者掌握 Go 在新一代 Web 技术栈中的应用能力。

    10

    2026.02.02

    PHP Swoole 高性能服务开发
    PHP Swoole 高性能服务开发

    本专题聚焦 PHP Swoole 扩展在高性能服务端开发中的应用,系统讲解协程模型、异步IO、TCP/HTTP/WebSocket服务器、进程与任务管理、常驻内存架构设计。通过实战案例,帮助开发者掌握 使用 PHP 构建高并发、低延迟服务端应用的工程化能力。

    3

    2026.02.02

    Java JNI 与本地代码交互实战
    Java JNI 与本地代码交互实战

    本专题系统讲解 Java 通过 JNI 调用 C/C++ 本地代码的核心机制,涵盖 JNI 基本原理、数据类型映射、内存管理、异常处理、性能优化策略以及典型应用场景(如高性能计算、底层库封装)。通过实战示例,帮助开发者掌握 Java 与本地代码混合开发的完整流程。

    4

    2026.02.02

    go语言 注释编码
    go语言 注释编码

    本专题整合了go语言注释、注释规范等等内容,阅读专题下面的文章了解更多详细内容。

    62

    2026.01.31

    go语言 math包
    go语言 math包

    本专题整合了go语言math包相关内容,阅读专题下面的文章了解更多详细内容。

    55

    2026.01.31

    go语言输入函数
    go语言输入函数

    本专题整合了go语言输入相关教程内容,阅读专题下面的文章了解更多详细内容。

    27

    2026.01.31

    golang 循环遍历
    golang 循环遍历

    本专题整合了golang循环遍历相关教程,阅读专题下面的文章了解更多详细内容。

    33

    2026.01.31

    热门下载

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

    精品课程

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

    共42课时 | 5.3万人学习

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

    共132课时 | 10.1万人学习

    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号