<span id="mktg5"></span>

<i id="mktg5"><meter id="mktg5"></meter></i>

        <label id="mktg5"><meter id="mktg5"></meter></label>
        最新文章專題視頻專題問答1問答10問答100問答1000問答2000關(guān)鍵字專題1關(guān)鍵字專題50關(guān)鍵字專題500關(guān)鍵字專題1500TAG最新視頻文章推薦1 推薦3 推薦5 推薦7 推薦9 推薦11 推薦13 推薦15 推薦17 推薦19 推薦21 推薦23 推薦25 推薦27 推薦29 推薦31 推薦33 推薦35 推薦37視頻文章20視頻文章30視頻文章40視頻文章50視頻文章60 視頻文章70視頻文章80視頻文章90視頻文章100視頻文章120視頻文章140 視頻2關(guān)鍵字專題關(guān)鍵字專題tag2tag3文章專題文章專題2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章專題3
        問答文章1 問答文章501 問答文章1001 問答文章1501 問答文章2001 問答文章2501 問答文章3001 問答文章3501 問答文章4001 問答文章4501 問答文章5001 問答文章5501 問答文章6001 問答文章6501 問答文章7001 問答文章7501 問答文章8001 問答文章8501 問答文章9001 問答文章9501
        當前位置: 首頁 - 科技 - 知識百科 - 正文

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

        來源:懂視網(wǎng) 責(zé)編:小采 時間:2020-11-27 22:29:07
        文檔

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

        jQuery使用zTree插件實現(xiàn)可拖拽的樹示例:在目前接觸到的樹插件中,我覺得zTree比較簡單,也容易上手。有一次業(yè)務(wù)需求是將某對象分組樹上的對象可以隨意拖拽,相當于改變了對象的分組,因此我用到了zTree,對其進行了一些列學(xué)習(xí)。 首先下載zTree所需的相關(guān)包,附上官方下載連接:zTree下載,引
        推薦度:
        導(dǎo)讀jQuery使用zTree插件實現(xiàn)可拖拽的樹示例:在目前接觸到的樹插件中,我覺得zTree比較簡單,也容易上手。有一次業(yè)務(wù)需求是將某對象分組樹上的對象可以隨意拖拽,相當于改變了對象的分組,因此我用到了zTree,對其進行了一些列學(xué)習(xí)。 首先下載zTree所需的相關(guān)包,附上官方下載連接:zTree下載,引

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

         首先下載zTree所需的相關(guān)包,附上官方下載連接:zTree下載,引入相關(guān)文件后就可以進行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一定要設(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é)點",
         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ī)則對能否拖拽,拖拽能否成功進行了相應(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){
         //暫時沒用到
        }
        
        //拖拽移動到展開父節(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;
        }
        
        //預(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"); 
        

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

         

        聲明:本網(wǎng)頁內(nèi)容旨在傳播知識,若有侵權(quán)等問題請及時與本網(wǎng)聯(lián)系,我們將在第一時間刪除處理。TEL:177 7030 7066 E-MAIL:11247931@qq.com

        文檔

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

        jQuery使用zTree插件實現(xiàn)可拖拽的樹示例:在目前接觸到的樹插件中,我覺得zTree比較簡單,也容易上手。有一次業(yè)務(wù)需求是將某對象分組樹上的對象可以隨意拖拽,相當于改變了對象的分組,因此我用到了zTree,對其進行了一些列學(xué)習(xí)。 首先下載zTree所需的相關(guān)包,附上官方下載連接:zTree下載,引
        推薦度:
        • 熱門焦點

        最新推薦

        猜你喜歡

        熱門推薦

        專題
        Top
        主站蜘蛛池模板: 久久久久免费看成人影片| 亚洲女人初试黑人巨高清| 亚洲欧美成aⅴ人在线观看| 美女内射无套日韩免费播放| 亚洲午夜国产片在线观看| 国产偷国产偷亚洲清高APP| 大香人蕉免费视频75| 亚洲乱码在线观看| 手机在线看永久av片免费| 亚洲国产综合精品| 国产v精品成人免费视频400条| 99久久综合精品免费| 国产亚洲无线码一区二区| 国产成人免费ā片在线观看老同学| 免费国产午夜高清在线视频| 亚洲综合区小说区激情区| eeuss免费影院| 亚洲精品你懂的在线观看| 最好免费观看高清在线| 亚洲国产精品免费视频| 91福利视频免费观看| 亚洲国产午夜精品理论片| 国产情侣激情在线视频免费看| 亚洲精品视频免费| 一级特黄色毛片免费看| 久久亚洲国产精品五月天婷| 2022免费国产精品福利在线| 久久亚洲高清观看| 97公开免费视频| 亚洲中文字幕久久精品蜜桃| 国产青草视频免费观看97| 丰满少妇作爱视频免费观看| 亚洲狠狠婷婷综合久久久久| 99爱在线观看免费完整版| 亚洲人xxx日本人18| 国产一区二区三区免费视频| 国产精品玖玖美女张开腿让男人桶爽免费看 | 亚洲视频欧洲视频| 国产精品免费观看| 久久人午夜亚洲精品无码区| 亚洲国产精品不卡毛片a在线|