jQuery的ztree仿windows文件新建和拖拽功能的实现代
网络编程 2021-07-04 16:47www.168986.cn编程入门
zTree 是一个依靠 jQuery 实现的多功能 “树插件”。优异的性能、灵活的配置、多种功能的组合是 zTree 最大优点。这篇文章主要介绍了jQuery的ztree仿windows文件新建和拖拽功能的实现代码,需要的朋友可以参考下
前面的话zTree 是一个依靠 jQuery 实现的多功能 “树插件”。优异的性能、灵活的配置、多种功能的组合是 zTree 最大优点。专门适合项目开发,尤其是 树状菜单、树状数据。
ztree官方文档
想要实现的效果
需要的功能
1实现一颗jQuery的ztree的树形菜单,这个很简单,直接引用官方文档即可
2点击新建组的按钮,会出现一个input对话框,填写想要新建的名称,在树形菜单上添加了一个父节点菜单。
3可以把其他父节点里面的子节点元素拖动到刚刚新建的父节点里面。
狼蚁网站SEO优化开始撸代码
1要引入一些必要的文件,可自己在官方文档里面下载。
<!-- 树形菜单 --> <link rel="stylesheet" href="../../mon/ztree/css/zTreeStyle/zTreeStyle.css" rel="external nofollow" > <script type="text/javascript" src="../../js/jquery-1.9.1.js" /></script> <script src="../../mon/ztree/js/jquery.ztree.all.min.js"></script>
2html界面,有新建组的按钮和盛放树形菜单的容器,还有填写文件名的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>
3css,这里的css样式是自己对于官方文档的一些修改,放了一些必要的图标,更加的生动形象。
#add{ width:80px; height:30px; background:#2299ee; color:#ffffff; border:none; margin-: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: ; 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: ; 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: ; 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: ; 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', suess : 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); } })
以上所述是长沙网络推广给大家介绍的jQuery的ztree仿windows文件新建和拖拽功能的实现代码,希望对大家有所帮助,如果大家有任何疑问请给我留言,长沙网络推广会及时回复大家的。在此也非常感谢大家对狼蚁SEO网站的支持!
编程语言
- 如何快速学会编程 如何快速学会ug编程
- 免费学编程的app 推荐12个免费学编程的好网站
- 电脑怎么编程:电脑怎么编程网咯游戏菜单图标
- 如何写代码新手教学 如何写代码新手教学手机
- 基础编程入门教程视频 基础编程入门教程视频华
- 编程演示:编程演示浦丰投针过程
- 乐高编程加盟 乐高积木编程加盟
- 跟我学plc编程 plc编程自学入门视频教程
- ug编程成航林总 ug编程实战视频
- 孩子学编程的好处和坏处
- 初学者学编程该从哪里开始 新手学编程从哪里入
- 慢走丝编程 慢走丝编程难学吗
- 国内十强少儿编程机构 中国少儿编程机构十强有
- 成人计算机速成培训班 成人计算机速成培训班办
- 孩子学编程网上课程哪家好 儿童学编程比较好的
- 代码编程教学入门软件 代码编程教程