国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > JavaScript > 正文

jQuery使用zTree插件實(shí)現(xiàn)可拖拽的樹示例

2019-11-19 15:19:22
字體:
供稿:網(wǎng)友

在目前接觸到的樹插件中,我覺得zTree比較簡單,也容易上手。有一次業(yè)務(wù)需求是將某對象分組樹上的對象可以隨意拖拽,相當(dāng)于改變了對象的分組,因此我用到了zTree,對其進(jìn)行了一些列學(xué)習(xí)。

 首先下載zTree所需的相關(guān)包,附上官方下載連接:zTree下載,引入相關(guān)文件后就可以進(jìn)行zTree的構(gòu)建了。首先在頁面上加ul標(biāo)簽,然后為樹加上id,calss為ztree,前端頁面就完成了。

注意:下面所有的代碼是根據(jù)我自己的需求寫的,且不完整,主要參考配置流程和回調(diào)函數(shù)的使用即可。

前端頁面:

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

然后寫JavaScript,寫之前一定要多多閱讀zTree的官方API,上面已經(jīng)解釋的很詳細(xì)了,只需要照著一步一步做即可。首先就是配置setting,這個(gè)是整個(gè)zTree的核心配置,我這里除了基本配置外,因?yàn)樾枰献Чδ埽虼伺渲昧薳dit,其中enable一定要設(shè)為true,其他參數(shù)看需求配置。callback中也配置相關(guān)的回調(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é)點(diǎn)",  renameTitle: "編輯節(jié)點(diǎn)名稱",  showRemoveBtn: false,  showRenameBtn: false, }, callback: {  beforeClick: beforeClick,  beforeDrag:beforeDrag,  beforeDragOpen:beforeDragOpen,  beforeDrop:beforeDrop,  onDrag:onDr},}; 

 配置完setting,將各個(gè)回調(diào)函數(shù)補(bǔ)充完整,根據(jù)需求來定里面的內(nèi)容,我這里根據(jù)父節(jié)點(diǎn)的類型以及一些其他一些規(guī)則對能否拖拽,拖拽能否成功進(jìn)行了相應(yīng)的限制。

 回調(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; }}//預(yù)留被拖拽的回調(diào)函數(shù)function onDrag(event, treeId, treeNode){ //暫時(shí)沒用到}//拖拽移動(dòng)到展開父節(jié)點(diǎn)之前調(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;}//預(yù)留拖拽結(jié)束的回調(diào)函數(shù)function onDrop(event, treeId, treeNode, targetNode, moveType){ befod('hide'); return result;}//預(yù)留拖拽結(jié)束的回調(diào)函數(shù)function onDrop(event, treeId, treeNode, targetNode, moveType){ beforeClick(treeId, treeNode[0]);} 

上面的設(shè)置和相關(guān)函數(shù)完成以后,就可以調(diào)用zTree的初始化方法,通過Ajax請求回來的參數(shù)去填充我們所需要的樹了。

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

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

 

以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持武林網(wǎng)。

發(fā)表評論 共有條評論
用戶名: 密碼:
驗(yàn)證碼: 匿名發(fā)表
主站蜘蛛池模板: 宜宾市| 敦化市| 桂林市| 大化| 城市| 南江县| 府谷县| 油尖旺区| 封丘县| 额尔古纳市| 江安县| 周宁县| 普陀区| 额尔古纳市| 余姚市| 龙州县| 迭部县| 增城市| 海南省| 阿拉善左旗| 阳曲县| 文水县| 平定县| 石家庄市| 翼城县| 司法| 榆林市| 通江县| 太仆寺旗| 宁蒗| 公安县| 虹口区| 象山县| 莱西市| 彰化县| 青浦区| 玉门市| 玉田县| 林芝县| 兴宁市| 泰顺县|