0

0

jQuery使用zTree插件实现可拖拽的树代码分享

小云云

小云云

发布时间:2018-02-02 13:31:00

|

1780人浏览过

|

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

     回调函数:

    Snowy(SnowyAdmin)快速开发平台3.5.1
    Snowy(SnowyAdmin)快速开发平台3.5.1

    Snowy(SnowyAdmin)是国内首个国密前后端分离快速开发平台,集成国密加解密插件, 软件层面完全符合等保测评要求,同时实现国产化机型、中间件、数据库适配,是您的不二之选! 技术框架与密码结合,让更多的人认识密码,使用密码;更是让前后分离“密”不可分。采用SpringBoot+MybatisPlus+AntDesignVue+Vite 等更多组件及前沿技术开发,注释丰富,代码简洁,开箱即用

    下载


     //拖拽之前调用的函数
    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技巧

    在AngularJS中使用jQuery的zTree插件的方法_AngularJS

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

    相关专题

    更多
    js获取数组长度的方法
    js获取数组长度的方法

    在js中,可以利用array对象的length属性来获取数组长度,该属性可设置或返回数组中元素的数目,只需要使用“array.length”语句即可返回表示数组对象的元素个数的数值,也就是长度值。php中文网还提供JavaScript数组的相关下载、相关课程等内容,供大家免费下载使用。

    556

    2023.06.20

    js刷新当前页面
    js刷新当前页面

    js刷新当前页面的方法:1、reload方法,该方法强迫浏览器刷新当前页面,语法为“location.reload([bForceGet]) ”;2、replace方法,该方法通过指定URL替换当前缓存在历史里(客户端)的项目,因此当使用replace方法之后,不能通过“前进”和“后退”来访问已经被替换的URL,语法为“location.replace(URL) ”。php中文网为大家带来了js刷新当前页面的相关知识、以及相关文章等内容

    374

    2023.07.04

    js四舍五入
    js四舍五入

    js四舍五入的方法:1、tofixed方法,可把 Number 四舍五入为指定小数位数的数字;2、round() 方法,可把一个数字舍入为最接近的整数。php中文网为大家带来了js四舍五入的相关知识、以及相关文章等内容

    733

    2023.07.04

    js删除节点的方法
    js删除节点的方法

    js删除节点的方法有:1、removeChild()方法,用于从父节点中移除指定的子节点,它需要两个参数,第一个参数是要删除的子节点,第二个参数是父节点;2、parentNode.removeChild()方法,可以直接通过父节点调用来删除子节点;3、remove()方法,可以直接删除节点,而无需指定父节点;4、innerHTML属性,用于删除节点的内容。

    477

    2023.09.01

    JavaScript转义字符
    JavaScript转义字符

    JavaScript中的转义字符是反斜杠和引号,可以在字符串中表示特殊字符或改变字符的含义。本专题为大家提供转义字符相关的文章、下载、课程内容,供大家免费下载体验。

    414

    2023.09.04

    js生成随机数的方法
    js生成随机数的方法

    js生成随机数的方法有:1、使用random函数生成0-1之间的随机数;2、使用random函数和特定范围来生成随机整数;3、使用random函数和round函数生成0-99之间的随机整数;4、使用random函数和其他函数生成更复杂的随机数;5、使用random函数和其他函数生成范围内的随机小数;6、使用random函数和其他函数生成范围内的随机整数或小数。

    1011

    2023.09.04

    如何启用JavaScript
    如何启用JavaScript

    JavaScript启用方法有内联脚本、内部脚本、外部脚本和异步加载。详细介绍:1、内联脚本是将JavaScript代码直接嵌入到HTML标签中;2、内部脚本是将JavaScript代码放置在HTML文件的`<script>`标签中;3、外部脚本是将JavaScript代码放置在一个独立的文件;4、外部脚本是将JavaScript代码放置在一个独立的文件。

    658

    2023.09.12

    Js中Symbol类详解
    Js中Symbol类详解

    javascript中的Symbol数据类型是一种基本数据类型,用于表示独一无二的值。Symbol的特点:1、独一无二,每个Symbol值都是唯一的,不会与其他任何值相等;2、不可变性,Symbol值一旦创建,就不能修改或者重新赋值;3、隐藏性,Symbol值不会被隐式转换为其他类型;4、无法枚举,Symbol值作为对象的属性名时,默认是不可枚举的。

    553

    2023.09.20

    PS使用蒙版相关教程
    PS使用蒙版相关教程

    本专题整合了ps使用蒙版相关教程,阅读专题下面的文章了解更多详细内容。

    23

    2026.01.19

    热门下载

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

    精品课程

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

    共42课时 | 4.4万人学习

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

    共132课时 | 9.6万人学习

    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号