jQuery的ztree仿windows檔案新建和拖拽效果
阿新 • • 發佈:2018-12-10
前面的話:zTree 是一個依靠 jQuery 實現的多功能 “樹外掛”。優異的效能、靈活的配置、多種功能的組合是 zTree 最大優點。專門適合專案開發,尤其是 樹狀選單、樹狀資料。
ztree官方文件:http://www.treejs.cn/v3/api.php
想要實現的效果:
需要的功能:
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);
}
})
好了,到此為止,一個可以新增新的節點和拖拽樹形選單的功能就實現了。
熱門推薦:全棧工程師開發常用外掛、工具類庫,視訊,資料300G資源彙總
原文作者:祈澈姑娘;技術部落格:https://www.jianshu.com/u/05f416aefbe1
90後前端妹子,愛程式設計,愛運營,愛折騰。 堅持總結工作中遇到的技術問題,堅持記錄工作中所所思所見,歡迎大家一起探討交流。