在目前接触到的树插件中,我觉得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如何改变指定节点文本样式
# 拖拽
# 回调
# 进行了
# 就可以
# 自己的
# 我觉得
# 设为
# 所需
# 我用
# 对其
# 有一次
# 只需要
# 中也
# 所需要
# 接触到
# 树上
# 大家多多
# 不完整
# 上加
# 基本配置
相关文章:
大型企业网站制作流程,做网站需要注册公司吗?
保定网站制作方案定制,保定招聘的渠道有哪些?找工作的人一般都去哪里看招聘信息?
微信推文制作网站有哪些,怎么做微信推文,急?
如何在景安服务器上快速搭建个人网站?
如何通过网站建站时间优化SEO与用户体验?
东莞市网站制作公司有哪些,东莞找工作用什么网站好?
如何用VPS主机快速搭建个人网站?
简单实现Android文件上传
常州自助建站工具推荐:低成本搭建与模板选择技巧
如何打造高效商业网站?建站目的决定转化率
手机怎么制作网站教程步骤,手机怎么做自己的网页链接?
建站主机系统SEO优化与智能配置核心关键词操作指南
nginx修改上传文件大小限制的方法
如何生成腾讯云建站专用兑换码?
建站主机数据库如何配置才能提升网站性能?
油猴 教程,油猴搜脚本为什么会网页无法显示?
道歉网站制作流程,世纪佳缘致歉小吴事件,相亲网站身份信息伪造该如何稽查?
建站之星北京办公室:智能建站系统与小程序生成方案解析
如何在宝塔面板中修改默认建站目录?
招商网站制作流程,网站招商广告语?
杭州银行网站设计制作流程,杭州银行怎么开通认证方式?
制作网页的网站有哪些,电脑上怎么做网页?
高性能网站服务器部署指南:稳定运行与安全配置优化方案
如何快速搭建高效服务器建站系统?
表情包在线制作网站免费,表情包怎么弄?
成都品牌网站制作公司,成都营业执照年报网上怎么办理?
建站VPS配置与SEO优化指南:关键词排名提升策略
如何制作网站标识牌,动态网站如何制作(教程)?
如何续费美橙建站之星域名及服务?
定制建站如何定义?其核心优势是什么?
商务网站制作工程师,从哪几个方面把握电子商务网站主页和页面的特色设计?
如何配置FTP站点权限与安全设置?
在线制作视频的网站有哪些,电脑如何制作视频短片?
网站制作的软件有哪些,制作微信公众号除了秀米还有哪些比较好用的平台?
建站之星微信建站一键生成小程序+多端营销系统
英语简历制作免费网站推荐,如何将简历翻译成英文?
制作网站软件推荐手机版,如何制作属于自己的手机网站app应用?
网站制作知乎推荐,想做自己的网站用什么工具比较好?
如何快速生成橙子建站落地页链接?
制作国外网站的软件,国外有哪些比较优质的网站推荐?
建站之星IIS配置教程:代码生成技巧与站点搭建指南
专业网站制作企业网站,如何制作一个企业网站,建设网站的基本步骤有哪些?
详解免费开源的.NET多类型文件解压缩组件SharpZipLib(.NET组件介绍之七)
建站主机与服务器功能差异如何区分?
如何通过西部数码建站助手快速创建专业网站?
网站建设制作、微信公众号,公明人民医院怎么在网上预约?
mc皮肤壁纸制作器,苹果平板怎么设置自己想要的壁纸我的世界?
威客平台建站流程解析:高效搭建教程与设计优化方案
网站专业制作公司,网站编辑是做什么的?好做吗?工作前景如何?
宝塔面板如何快速创建新站点?
*请认真填写需求信息,我们会在24小时内与您取得联系。