91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

jQuery使用zTree插件實現可拖拽的樹示例

發布時間:2020-10-10 08:13:52 來源:腳本之家 閱讀:183 作者:計算機-程浩 欄目:web開發

在目前接觸到的樹插件中,我覺得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使用zTree插件實現可拖拽的樹示例 

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持億速云。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

桃园县| 巴林右旗| 资源县| 林西县| 阜康市| 阿合奇县| 东海县| 镇安县| 泗洪县| 拜城县| 泰州市| 石台县| 南丹县| 荆门市| 二连浩特市| 岳西县| 仪征市| 谢通门县| 大石桥市| 嵩明县| 洛浦县| 张家界市| 扬州市| 朔州市| 大悟县| 连平县| 齐齐哈尔市| 阳朔县| 泰安市| 阳曲县| 新兴县| 监利县| 大名县| 偃师市| 陇南市| 集贤县| 奈曼旗| 昌江| 彭阳县| 稷山县| 镇康县|