全网整合营销服务商

电脑端+手机端+微信端=数据同步管理

免费咨询热线:400-708-3566

jQuery使用zTree插件实现可拖拽的树示例

在目前接触到的树插件中,我觉得zTree比较简单,也容易上手。有一次业务需求是将某对象分组树上的对象可以随意拖拽,相当于改变了对象的分组,因此我用到了zTree,对其进行了一些列学习。

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

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

前端页面:

 <ul id="modelTree" class="ztree"></ul> 

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

 回调函数:

 //拖拽之前调用的函数
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"); 

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

 

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。


# jQuery  # 可拖拽的树  # jquery拖拽插件  # jQuery实现可拖拽树  # 基于jQuery ztree实现表格风格的树状结构  # jQuery zTree 异步加载添加子节点重复问题  # jQuery 利用ztree实现树形表格的实例代码  # zTree jQuery 树插件的使用(实例讲解)  # jQuery EasyUI结合zTree树形结构制作web页面  # jQuery zTree树插件动态加载实例代码  # jQuery插件zTree实现的多选树效果示例  # jQuery zTree如何改变指定节点文本样式  # 拖拽  # 回调  # 进行了  # 就可以  # 自己的  # 我觉得  # 设为  # 所需  # 我用  # 对其  # 有一次  # 只需要  # 中也  # 所需要  # 接触到  # 树上  # 大家多多  # 不完整  # 上加  # 基本配置 


相关文章: 建站之星如何保障用户数据免受黑客入侵?  购物网站制作公司有哪些,哪个购物网站比较好?  制作营销网站公司,淘特是干什么用的?  香港服务器WordPress建站指南:SEO优化与高效部署策略  建站之星北京办公室:智能建站系统与小程序生成方案解析  Avalonia如何实现跨窗口通信 Avalonia窗口间数据传递  香港服务器如何优化才能显著提升网站加载速度?  Python多线程使用规范_线程安全解析【教程】  完全自定义免费建站平台:主题模板在线生成一站式服务  如何快速搭建虚拟主机网站?新手必看指南  建站主机数据库如何配置才能提升网站性能?  如何快速建站并高效导出源代码?  如何用VPS主机快速搭建个人网站?  建站之星2.7模板:企业网站建设与h5定制设计专题  如何通过远程VPS快速搭建个人网站?  网站制作公司排行榜,四大门户网站排名?  用v-html解决Vue.js渲染中html标签不被解析的问题  网站制作软件有哪些,制图软件有哪些?  临沂网站制作企业,临沂第三中学官方网站?  广州建站公司哪家好?十大优质服务商推荐  建站中国必看指南:CMS建站系统+手机网站搭建核心技巧解析  专业企业网站设计制作公司,如何理解商贸企业的统一配送和分销网络建设?  国美网站制作流程,国美电器蒸汽鍋怎么用官方网站?  香港服务器建站指南:外贸独立站搭建与跨境电商配置流程  营销式网站制作方案,销售哪个网站招聘效果最好?  建站主机SSH密钥生成步骤及常见问题解答?  Dapper的Execute方法的返回值是什么意思 Dapper Execute返回值详解  如何基于云服务器快速搭建个人网站?  如何自定义建站之星网站的导航菜单样式?  MySQL查询结果复制到新表的方法(更新、插入)  网站制作和推广的区别,想自己建立一个网站做推广,有什么快捷方法马上做好一个网站?  如何解决ASP生成WAP建站中文乱码问题?  如何选择香港主机高效搭建外贸独立站?  微网站制作教程,我微信里的网站怎么才能复制到浏览器里?  网站专业制作公司,网站编辑是做什么的?好做吗?工作前景如何?  建站之星安全性能如何?防护体系能否抵御黑客入侵?  标准网站视频模板制作软件,现在有哪个网站的视频编辑素材最齐全的,背景音乐、音效等?  如何在腾讯云免费申请建站?  如何在IIS中新建站点并解决端口绑定冲突?  厦门模型网站设计制作公司,厦门航空飞机模型掉色怎么办?  如何制作网站标识牌,动态网站如何制作(教程)?  如何快速搭建FTP站点实现文件共享?  免费制作海报的网站,哪位做平面的朋友告诉我用什么软件做海报比较好?ps还是cd还是ai这几个软件我都会些我是做网页的?  高端建站如何打造兼具美学与转化的品牌官网?  在线流程图制作网站手机版,谁能推荐几个好的CG原画资源网站么?  手机钓鱼网站怎么制作视频,怎样拦截钓鱼网站。怎么办?  建站主机如何安装配置?新手必看操作指南  在线ppt制作网站有哪些,请推荐几个好的课件下载的网站?  建站之星在线客服如何快速接入解答?  c# await 一个已经完成的Task会发生什么 

您的项目需求

*请认真填写需求信息,我们会在24小时内与您取得联系。