jQuery使用zTree插件實現(xiàn)可拖拽的樹示例
在目前接觸到的樹插件中,我覺得zTree比較簡單,也容易上手。有一次業(yè)務需求是將某對象分組樹上的對象可以隨意拖拽,相當于改變了對象的分組,因此我用到了zTree,對其進行了一些列學習。
首先下載zTree所需的相關包,附上官方下載連接:zTree下載,引入相關文件后就可以進行zTree的構(gòu)建了。首先在頁面上加ul標簽,然后為樹加上id,calss為ztree,前端頁面就完成了。
注意:下面所有的代碼是根據(jù)我自己的需求寫的,且不完整,主要參考配置流程和回調(diào)函數(shù)的使用即可。
前端頁面:
<ul id="modelTree" class="ztree"></ul>
然后寫JavaScript,寫之前一定要多多閱讀zTree的官方API,上面已經(jīng)解釋的很詳細了,只需要照著一步一步做即可。首先就是配置setting,這個是整個zTree的核心配置,我這里除了基本配置外,因為需要拖拽功能,因此配置了edit,其中enable一定要設為true,其他參數(shù)看需求配置。callback中也配置相關的回調(diào)函數(shù)。
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: "刪除節(jié)點",
renameTitle: "編輯節(jié)點名稱",
showRemoveBtn: false,
showRenameBtn: false,
},
callback: {
beforeClick: beforeClick,
beforeDrag:beforeDrag,
beforeDragOpen:beforeDragOpen,
beforeDrop:beforeDrop,
onDrag:onDr},
};
配置完setting,將各個回調(diào)函數(shù)補充完整,根據(jù)需求來定里面的內(nèi)容,我這里根據(jù)父節(jié)點的類型以及一些其他一些規(guī)則對能否拖拽,拖拽能否成功進行了相應的限制。
回調(diào)函數(shù):
//拖拽之前調(diào)用的函數(shù)
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;
}
}
//預留被拖拽的回調(diào)函數(shù)
function onDrag(event, treeId, treeNode){
//暫時沒用到
}
//拖拽移動到展開父節(jié)點之前調(diào)用的函數(shù)
function beforeDragOpen(){
return true;
}
//拖拽操作結(jié)束之前調(diào)用的函數(shù)
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;
}
//預留拖拽結(jié)束的回調(diào)函數(shù)
function onDrop(event, treeId, treeNode, targetNode, moveType){
befod('hide');
return result;
}
//預留拖拽結(jié)束的回調(diào)函數(shù)
function onDrop(event, treeId, treeNode, targetNode, moveType){
beforeClick(treeId, treeNode[0]);
}
上面的設置和相關函數(shù)完成以后,就可以調(diào)用zTree的初始化方法,通過Ajax請求回來的參數(shù)去填充我們所需要的樹了。
// 初始化對象分組樹
var treeObj = $("#modelTree");
$.fn.zTree.init(treeObj, setting, data);
zTree_Menu = $.fn.zTree.getZTreeObj("modelTree");
最后形成的樹(可以拖拽的):
以上就是本文的全部內(nèi)容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。
相關文章
JQuery 確定css方框模型(盒模型Box Model)
做過前臺設置的都知道css存在兩種盒模型,W3C標準的方框模型和IE瀏覽器的方框模型。除IE以外的大多數(shù)瀏覽器只支持W3C方框模型。IE瀏覽器能夠根據(jù)頁面的呈現(xiàn)模式的定義而是用對性的方框模式。已用哪中呈現(xiàn)的模式取決于頁面上的DOCTYPE的聲明。2010-01-01
jQuery Ajax 仿AjaxPro.Utility.RegisterTypeForAjax輔助方法
我們都知道在AjaxPro的方法AjaxPro.Utility.RegisterTypeForAjax(typeof(所在類的類名));會將標記有[Ajax.AjaxMethod]方法注冊在客戶端。2011-09-09
jQuery實現(xiàn)模擬flash頭像裁切上傳功能示例
這篇文章主要介紹了jQuery實現(xiàn)模擬flash頭像裁切上傳功能,結(jié)合實例形式分析了jQuery圖像剪切與文件傳輸相關操作技巧,需要的朋友可以參考下2016-12-12

