jQuery的ztree仿windows檔案新建和拖拽效果
前面的話: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);
}
})
好了,到此為止,一個可以新增新的節點和拖拽樹形選單的功能就實現了。
原文作者:祈澈姑娘;技術部落格:https://www.jianshu.com/u/05f416aefbe1
90後前端妹子,愛程式設計,愛運營,愛折騰。 堅持總結工作中遇到的技術問題,堅持記錄工作中所所思所見,歡迎大家一起探討交流。
相關文章
- jQuery zTree 展示樹形表格jQuery
- JavaScript拖拽效果JavaScript
- 仿Windows畫板噴漆筆刷效果Windows
- Linux——拖拽上傳檔案Linux
- canvas矩形拖拽效果Canvas
- 原生JS拖拽效果JS
- JavaScript 限定範圍的拖拽效果JavaScript
- HTML5拖拽檔案上傳HTML
- CSS 實現仿 Windows10 滑鼠照亮邊框效果CSSWindows
- 【ztree】zTree節點增刪改
- 獲取拖拽和剪貼簿中的檔案
- 在vue專案中jsPlumb製作流程圖,拖拽複製使用 jquery 和 jquery UIVueJS流程圖jQueryUI
- jQuery 效果方法jQuery
- 強大的CSS :實現仿 Windows10 滑鼠照亮邊框效果CSSWindows
- 檔案拖拽增強工具:Dropzone 4 for macMac
- Dropzone檔案快速拖拽操作增強工具
- 仿金山打字效果
- Android 高仿騰訊新聞視訊切換效果Android
- JavaScript元素拖拽路徑回放效果JavaScript
- Jquery實現拖拽式繪圖工具jQuery繪圖
- jQuery內容橫向拖拽滾動jQuery
- Dropzone 4 for Mac 檔案拖拽操作增強工具Mac
- Dropzone 4 for Mac(檔案拖拽程式訪問工具)Mac
- 檔案拖拽程式訪問工具:Dropzone 4 for MacMac
- Dropzone 4 for Mac(檔案拖拽操作增強工具)Mac
- Mac檔案拖拽操作增強工具:Dropzone 4Mac
- jQuery基礎 效果jQuery
- jQuery 放大鏡效果jQuery
- jQuery 效果 – 動畫jQuery動畫
- jQuery 效果 – 滑動jQuery
- SpringBoot2.0 redis生成組建和讀寫配置檔案Spring BootRedis
- 分散式檔案系統fastdfs_搭建和基本使用分散式AST
- 仿 “即刻APP” 滑動返回的效果APP
- 前端實現檔案下載和拖拽上傳前端
- 檔案拖拽增強工具:Dropzone 4 啟用版
- 使用BottomSheetBehavior實現美團拖拽效果
- jQuery 效果 – 停止動畫jQuery動畫
- jQuery 效果 – 淡入淡出jQuery