jQuery的ztree仿windows文件新建和拖拽功能的實(shí)現(xiàn)代碼
前面的話:zTree 是一個(gè)依靠 jQuery 實(shí)現(xiàn)的多功能 “樹(shù)插件”。優(yōu)異的性能、靈活的配置、多種功能的組合是 zTree 最大優(yōu)點(diǎn)。專門適合項(xiàng)目開(kāi)發(fā),尤其是 樹(shù)狀菜單、樹(shù)狀數(shù)據(jù)。
ztree官方文檔:http://www.treejs.cn/v3/api.php
想要實(shí)現(xiàn)的效果:

需要的功能:
1:首先實(shí)現(xiàn)一顆jQuery的ztree的樹(shù)形菜單,這個(gè)很簡(jiǎn)單,直接引用官方文檔即可
2:點(diǎn)擊新建組的按鈕,會(huì)出現(xiàn)一個(gè)input對(duì)話框,填寫想要新建的名稱,在樹(shù)形菜單上添加了一個(gè)父節(jié)點(diǎn)菜單。
3:可以把其他父節(jié)點(diǎn)里面的子節(jié)點(diǎn)元素拖動(dòng)到剛剛新建的父節(jié)點(diǎn)里面。
下面開(kāi)始擼代碼:
1:首先要引入一些必要的文件,可自己在官方文檔里面下載。
<!-- 樹(shù)形菜單 --> <link rel="stylesheet" href="../../common/ztree/css/zTreeStyle/zTreeStyle.css" rel="external nofollow" > <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界面,有新建組的按鈕和盛放樹(shù)形菜單的容器,還有填寫文件名的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樣式是自己對(duì)于官方文檔的一些修改,放了一些必要的圖標(biāo),更加的生動(dòng)形象。
#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:重點(diǎn)在于js,主要分為初始化ztree功能;添加分組功能;ztree結(jié)構(gòu)設(shè)置功能;
$(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);
});
}
// 點(diǎn)擊顯示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結(jié)構(gòu)設(shè)置
var setting = {
check : {
enable : true,
chkStyle : "radio",
radioType : "all"
},
async : {// 異步加載數(shù)據(jù)操作
enable : true,
url : path() + "/ztree",
autoParam : [ "id" ],
type : "get",
// dataFilter : ajaxDataFilter,//用于對(duì) Ajax 返回?cái)?shù)據(jù)進(jìn)行預(yù)處理的函數(shù)
dataType : "json"
},
edit : {
enable : true,
showRemoveBtn : false,// 設(shè)置是否顯示刪除按鈕
showRenameBtn : setRenameBtn,// 設(shè)置是否顯示重新命名按鈕
drag : {
isCopy : false,
isMove : true,
prev : true,
next : true,
inner : true
}
},
data : {
keep : {
parent : true
// 保持父節(jié)點(diǎn)的狀態(tài)
},
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,
}
// 設(shè)置父節(jié)點(diǎn)
$.ajax({
url : path() + '/ztree',
contentType : 'application/json',
type : 'put',
data : JSON.stringify(params),
error : function(data) {
alert("操作失敗?。?)
}
});
}
// 獲取項(xiàng)目路徑
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);
}
})
總結(jié)
以上所述是小編給大家介紹的jQuery的ztree仿windows文件新建和拖拽功能的實(shí)現(xiàn)代碼,希望對(duì)大家有所幫助,如果大家有任何疑問(wèn)請(qǐng)給我留言,小編會(huì)及時(shí)回復(fù)大家的。在此也非常感謝大家對(duì)腳本之家網(wǎng)站的支持!
- jQuery使用zTree插件實(shí)現(xiàn)可拖拽的樹(shù)示例
- jQuery zTree 異步加載添加子節(jié)點(diǎn)重復(fù)問(wèn)題
- jQuery 利用ztree實(shí)現(xiàn)樹(shù)形表格的實(shí)例代碼
- zTree jQuery 樹(shù)插件的使用(實(shí)例講解)
- jQuery插件zTree實(shí)現(xiàn)的多選樹(shù)效果示例
- jQuery插件zTree實(shí)現(xiàn)的基本樹(shù)與節(jié)點(diǎn)獲取操作示例
- jQuery插件zTree實(shí)現(xiàn)刪除樹(shù)節(jié)點(diǎn)的方法示例
- jQuery插件zTree實(shí)現(xiàn)獲取一級(jí)節(jié)點(diǎn)數(shù)據(jù)的方法
- jQuery插件zTree實(shí)現(xiàn)清空選中第一個(gè)節(jié)點(diǎn)所有子節(jié)點(diǎn)的方法
- jQuery插件zTree實(shí)現(xiàn)獲取當(dāng)前選中節(jié)點(diǎn)在同級(jí)節(jié)點(diǎn)中序號(hào)的方法
相關(guān)文章
jquery實(shí)現(xiàn)可拖動(dòng)DIV自定義保存到數(shù)據(jù)的實(shí)例
這篇文章主要介紹了jquery實(shí)現(xiàn)可拖動(dòng)DIV自定義保存到數(shù)據(jù),有需要的朋友可以參考一下2013-11-11
用jquery和json從后臺(tái)獲得數(shù)據(jù)集的代碼
最近正在用ajax無(wú)刷新做網(wǎng)站,發(fā)現(xiàn)數(shù)據(jù)很好傳輸,但是數(shù)據(jù)集不知道怎么獲得,于是,上網(wǎng)查了一些資料來(lái)傳輸數(shù)據(jù),現(xiàn)在和大家分享一下,不知道的童鞋可以和我一起學(xué)習(xí),知道的請(qǐng)指點(diǎn)一二。我選擇的方法是用json 來(lái)獲取數(shù)據(jù)集2011-11-11
Ajax搜索結(jié)果頁(yè)面下方的分頁(yè)按鈕的生成
前幾天在做項(xiàng)目的時(shí)候 遇到個(gè)小問(wèn)題,就是分頁(yè)結(jié)果的頁(yè)數(shù)太多一般5頁(yè)到10頁(yè)就結(jié)束了可是這個(gè)分頁(yè)結(jié)果有400多頁(yè)的當(dāng)時(shí)就有些抓狂了,后來(lái)想了想模仿搜索引擎的結(jié)果頁(yè)面2012-04-04
Javascript中封裝window.open解決不兼容問(wèn)題
window.open不兼容,其實(shí)不是, 因?yàn)椴荒苤苯訄?zhí)行, 必須通過(guò)用戶手動(dòng)觸發(fā)才行,下面有個(gè)實(shí)例,大家可以看看2014-09-09
jQuery獲取css z-index在各種瀏覽器中的返回值
jQuery 取 css z-index 值在各種瀏覽器中的返回值的代碼,需要的朋友可以參考下。2010-09-09
jquery.combobox中文api和例子,修復(fù)了上面的小bug
關(guān)于jquery.combobox,這個(gè)jquery的插件從官網(wǎng)上直接下載下來(lái)使用還有bug,以下是我對(duì)其api做的簡(jiǎn)單翻譯,而且修復(fù)了上面的bug。2011-03-03
JQueryEasyUI datagrid框架的進(jìn)階使用
本篇文章小編為大家介紹JQueryEasyUI datagrid框架的基本使用,有需要的朋友可以參考一下2013-04-04

