• <fieldset id="8imwq"><menu id="8imwq"></menu></fieldset>
  • <bdo id="8imwq"><input id="8imwq"></input></bdo>
    最新文章專題視頻專題問(wèn)答1問(wèn)答10問(wèn)答100問(wèn)答1000問(wèn)答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
    問(wèn)答文章1 問(wèn)答文章501 問(wèn)答文章1001 問(wèn)答文章1501 問(wèn)答文章2001 問(wèn)答文章2501 問(wèn)答文章3001 問(wèn)答文章3501 問(wèn)答文章4001 問(wèn)答文章4501 問(wèn)答文章5001 問(wèn)答文章5501 問(wèn)答文章6001 問(wèn)答文章6501 問(wèn)答文章7001 問(wèn)答文章7501 問(wèn)答文章8001 問(wèn)答文章8501 問(wèn)答文章9001 問(wèn)答文章9501
    當(dāng)前位置: 首頁(yè) - 科技 - 知識(shí)百科 - 正文

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

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

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

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

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

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

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

    前端頁(yè)面:

     <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ù)需求來(lái)定里面的內(nèi)容,我這里根據(jù)父節(jié)點(diǎn)的類型以及一些其他一些規(guī)則對(duì)能否拖拽,拖拽能否成功進(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的初始化方法,通過(guò)Ajax請(qǐng)求回來(lái)的參數(shù)去填充我們所需要的樹了。

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

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

     

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

    文檔

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

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

    最新推薦

    猜你喜歡

    熱門推薦

    專題
    Top
    主站蜘蛛池模板: 欧美精品VIDEOSSEX少妇| 97r久久精品国产99国产精| 精品福利视频一区二区三区| 久久国产精品视频| 四虎影视国产精品亚洲精品hd| 久久久久久国产精品免费无码 | 鲸鱼传媒绿头鱼实验室之炮机测评日韩精品一级毛 | 蜜国产精品jk白丝AV网站 | 麻豆成人久久精品二区三区免费| 欧美精品www| 国产人成精品综合欧美成人| 欧美精品香蕉在线观看网| 国产成人精品免费久久久久| 色婷婷在线精品国自产拍| 日韩福利视频精品专区| 国产亚洲美女精品久久久| 亚洲国产精品国自产电影| 国产a精品视频| 91麻豆精品国产| 999国内精品永久免费视频| 久久精品国产亚洲av麻豆色欲| 亚洲国产美女精品久久久久∴| 亚洲AV无码之日韩精品| 免费看一级毛片在线观看精品视频 | 91麻精品国产91久久久久| 久久精品国产一区| 久久99精品国产99久久| 99精品久久久久中文字幕| 99re8这里有精品热视频免费| 3D动漫精品一区二区三区| 2022国内精品免费福利视频| 国产精品区一区二区三在线播放| 精品国产福利一区二区| 成人区精品一区二区不卡| 国产精品免费无遮挡无码永久视频 | 成人精品在线视频| 国产精品久久影院| 青青青国产依人精品视频| 日韩麻豆国产精品欧美| 国产成人精品久久亚洲高清不卡| 国产精品日日摸夜夜添夜夜添1国产精品va欧美精 |