jQuery的ztree仿windows檔案新建和拖拽效果

weixin_34249678發表於2018-12-03

前面的話:zTree 是一個依靠 jQuery 實現的多功能 “樹外掛”。優異的效能、靈活的配置、多種功能的組合是 zTree 最大優點。專門適合專案開發,尤其是 樹狀選單、樹狀資料。

ztree官方文件:http://www.treejs.cn/v3/api.php

想要實現的效果:


5640239-6265f0af9e9966e4.gif

需要的功能:

1:首先實現一顆jQuery的ztree的樹形選單,這個很簡單,直接引用官方文件即可
2:點選新建組的按鈕,會出現一個input對話方塊,填寫想要新建的名稱,在樹形選單上新增了一個父節點選單。
3:可以把其他父節點裡面的子節點元素拖動到剛剛新建的父節點裡面。

下面開始擼程式碼:

1:首先要引入一些必要的檔案,可自己在官方文件裡面下載。

<!-- 樹形選單 -->
<link rel="stylesheet"  href="../../common/ztree/css/zTreeStyle/zTreeStyle.css">
<script type="text/javascript" src="../../js/jquery-1.9.1.js" /></script>   
<script src="../../common/ztree/js/jquery.ztree.all.min.js"></script>

2:html介面,有新建組的按鈕和盛放樹形選單的容器,還有填寫檔名的input框以及提交按鈕。

    <div class="">
                           <div>
                                <button id="add">新建組</button>
                            </div>
                            <div>
                                <ul id="ztree" class="ztree"></ul>
                            </div>
                            <div id="addgroup" style="display: none">
                                <input type="text" id="group" name="group">
                                <button id="submit">提交</button>
                            </div>
                    
                </div>

3:css,這裡的css樣式是自己對於官方文件的一些修改,放了一些必要的圖示,更加的生動形象。

#add{
    width:80px;
    height:30px;
    background:#2299ee;
    color:#ffffff;
    border:none;
    margin-top:10px;
    margin-bottom:10px;
}

.ztree li span.button.icon01_ico_close {
    margin-right: 2px;
    background: url(../../images/ztree/close.png) no-repeat scroll 0 0 transparent;
    vertical-align: top;
    *vertical-align: middle
}

.ztree li span.button.icon01_ico_open {
    margin-right: 2px;
    background: url(../../images/ztree/open.png) no-repeat scroll 0 0 transparent;
    vertical-align: top;
    *vertical-align: middle
}

.ztree li span.button.icon02_ico_docu {
    margin-right: 2px;
    background: url(../../images/ztree/woman.png) no-repeat scroll 0 0 transparent;
    vertical-align: top;
    *vertical-align: middle
}

.ztree li span.button.icon03_ico_docu {
    margin-right: 2px;
    background: url(../../images/ztree/man.png) no-repeat scroll 0 0 transparent;
    vertical-align: top;
    *vertical-align: middle
}


4:重點在於js,主要分為初始化ztree功能;新增分組功能;ztree結構設定功能;

$(function() {

    var zTreeObj;

    // 初始化ztree
    initTree();

    function initTree() {
        $.get(path() + "/ztree/init", function(data) {
            for ( var i in data) {
                if (data[i].token == "3")
                    data[i].nocheck = true;
            }
            zTreeObj = $.fn.zTree.init($("#ztree"), setting, data);
        });
    }
    // 點選顯示div
    $("#add").click(function() {
        $("#addgroup").show();
    })

    // 新增分組
    $("#submit").click(function() {
        $.ajax({
            url : path() + '/ztree/group/' + $("#group").val(),
            type : 'post',
            success : function(data) {
                $("#addgroup").hide();
                // 重新載入
                initTree();
            },
            error : function(data) {
                alert("新增分組失敗!!")
            }
        });
    })

    // ztree結構設定
    var setting = {
        check : {
            enable : true,
            chkStyle : "radio",
            radioType : "all"
        },
        async : {// 非同步載入資料操作
            enable : true,
            url : path() + "/ztree",
            autoParam : [ "id" ],
            type : "get",
            // dataFilter : ajaxDataFilter,//用於對 Ajax 返回資料進行預處理的函式
            dataType : "json"
        },
        edit : {
            enable : true,
            showRemoveBtn : false,// 設定是否顯示刪除按鈕
            showRenameBtn : setRenameBtn,// 設定是否顯示重新命名按鈕
            drag : {
                isCopy : false,
                isMove : true,
                prev : true,
                next : true,
                inner : true
            }
        },
        data : {
            keep : {
                parent : true
            // 保持父節點的狀態
            },
            simpleData : {
                enable : true,
                idKey : "id",
                pIdKey : "pId"
            }
        },
        callback : {
            beforeDrag : beforeDrag,
            beforeDrop : zTreeBeforeDrop,
            onDrop : onDrop,
            onRename : zTreeOnRename,
        }
    };

    function setRenameBtn(treeId, treeNode) {
        return treeNode.isParent;
    }

    function zTreeOnRename(event, treeId, treeNode, isCancel) {
        if (treeNode.name == '')
            return;
        var params = {
            id : treeNode.id,
            name : treeNode.name,
        }
        $.ajax({
            url : path() + '/ztree/group',
            contentType : 'application/json',
            type : 'post',
            data : JSON.stringify(params),
            error : function(data) {
                alert("操作失敗!!")
            }
        });
    }

    function beforeDrag(treeId, treeNodes) {
        for (var i = 0, l = treeNodes.length; i < l; i++) {
            if (treeNodes[i].token == "3") {
                return false;
            }
        }
        return true;
    }

    function zTreeBeforeDrop(treeId, treeNodes, targetNode, moveType) {
        if (targetNode.token != '3') {
            return false;
        }
        return true;
    }

    function onDrop(event, treeId, treeNodes, targetNode, moveType, isCopy) {
        if (moveType == null)
            return;

        var params = {
            id : treeNodes[0].id,
            pId : targetNode.id,
            token : moveType,
        }
        // 設定父節點
        $.ajax({
            url : path() + '/ztree',
            contentType : 'application/json',
            type : 'put',
            data : JSON.stringify(params),
            error : function(data) {
                alert("操作失敗!!")
            }
        });

    }

    

    // 獲取專案路徑
    function path() {
        var currentPath = window.document.location.href;
        var pathName = window.document.location.pathname;
        var pos = currentPath.indexOf(pathName);
        var localhostPath = currentPath.substring(0, pos);
        var projectName = pathName.substring(0,
                pathName.substr(1).indexOf('/') + 1);
        return (localhostPath + projectName);
    }

})


好了,到此為止,一個可以新增新的節點和拖拽樹形選單的功能就實現了。

原文作者:祈澈姑娘;技術部落格:https://www.jianshu.com/u/05f416aefbe1
90後前端妹子,愛程式設計,愛運營,愛折騰。 堅持總結工作中遇到的技術問題,堅持記錄工作中所所思所見,歡迎大家一起探討交流。

相關文章