zoukankan      html  css  js  c++  java
  • jQuery zTree v3.5 实例5 对树节点的增、删、改,添加时包含添加同级节点和子节点

    最终效果如下:

    当鼠标移动到节点时,后面会出现三个小图标,依次代表添加、修改和删除。修改和删除可以参看上一篇文章,这篇重点在于添加。在点击添加小图标时,效果如下:

    会弹出对话框,提示用户是添加同级节点还是子节点,如果当前节点是叶子节点,则不能添加同级节点,因为这可以由它的父节点添加子节点来完成。这样一来,添加的同级节点都是父节点,即isParent:true。

    弹出的对话框使用到了artDialog,可网上下载。

    代码如下:

    <%@ page language="java" contentType="text/html; charset=utf-8"
        pageEncoding="utf-8"%>
            <%
    String path = request.getContextPath();
    String basePath = request.getScheme()+"://"+request.getServerName()+":"+request.getServerPort()+path+"/";
    %>
    <!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
    <html>
    <head>
    <meta http-equiv="Content-Type" content="text/html; charset=utf-8">
    <title>Insert title here</title>
    </head>
    <script type="text/javascript" src="<%=basePath %>/js/jquery-1.8.1.js"></script>
    	<script type="text/javascript" src="<%=basePath %>/js/jquery.ztree.all-3.5.min.js"></script>
    	<script type="text/javascript" src="<%=basePath %>/js/jquery.artDialog.js"></script>
    	<link href="<%=basePath %>/css/zTreeStyle.css" rel="stylesheet" type="text/css"/>
    	<link href="<%=basePath %>/css/idialog.css" rel="stylesheet" type="text/css"/>
    	<script type="text/javascript">
    	var zTree;
    	var setting = {
    			view:{
    				addHoverDom:addHoverDom,
    				removeHoverDom:removeHoverDom,
    				selectedMulti:false
    			},
    			edit: {
    				enable: true,
    				editNameSelectAll:true,
    				removeTitle:'删除',
    				renameTitle:'重命名'
    			},
    			data: {
    				/* keep:{
    					parent:true,
    					leaf:true
    				}, */
    				simpleData: {
    					enable: true
    				}
    			},
    			callback:{
    				beforeRemove:beforeRemove,//点击删除时触发,用来提示用户是否确定删除
    				beforeEditName: beforeEditName,//点击编辑时触发,用来判断该节点是否能编辑
    				beforeRename:beforeRename,//编辑结束时触发,用来验证输入的数据是否符合要求
    				onRemove:onRemove,//删除节点后触发,用户后台操作
    				onRename:onRename,//编辑后触发,用于操作后台
    				beforeDrag:beforeDrag,//用户禁止拖动节点
    				onClick:clickNode//点击节点触发的事件
    			}
    		};
    	var zNodes =[
    	 			{ id:1, pId:0, name:"父节点 1", open:true},
    	 			{ id:11, pId:1, name:"去百度",url:'http://www.baidu.com',target:'_blank'},
    	 			{ id:12, pId:1, name:"叶子节点 1-2"},
    	 			{ id:13, pId:1, name:"叶子节点 1-3"},
    	 			{ id:2, pId:0, name:"父节点 2", open:true},
    	 			{ id:21, pId:2, name:"叶子节点 2-1"},
    	 			{ id:22, pId:2, name:"叶子节点 2-2"},
    	 			{ id:23, pId:2, name:"叶子节点 2-3"},
    	 			{ id:3, pId:0, name:"父节点 3", open:true},
    	 			{ id:31, pId:3, name:"叶子节点 3-1"},
    	 			{ id:32, pId:3, name:"叶子节点 3-2"},
    	 			{ id:33, pId:3, name:"叶子节点 3-3"}
    	 		];
    	$(document).ready(function(){
    		zTree = $.fn.zTree.init($("#tree"), setting, zNodes);
    	});
    	function beforeRemove(e,treeId,treeNode){
    		return confirm("你确定要删除吗?");
    	}
    	function onRemove(e,treeId,treeNode){
    		if(treeNode.isParent){
    			var childNodes = zTree.removeChildNodes(treeNode);
    			var paramsArray = new Array();
    			for(var i = 0; i < childNodes.length; i++){
    				paramsArray.push(childNodes[i].id);
    			}
    			alert("删除父节点的id为:"+treeNode.id+"
    他的孩子节点有:"+paramsArray.join(","));
    			return;
    		}
    		alert("你点击要删除的节点的名称为:"+treeNode.name+"
    "+"节点id为:"+treeNode.id);
    	}
    	function beforeEditName(treeId,treeNode){
    		/* if(treeNode.isParent){
    			alert("不准编辑非叶子节点!");
    			return false;
    		} */
    		return true;
    	}
    	function beforeRename(treeId,treeNode,newName,isCancel){
    		if(newName.length < 3){
    			alert("名称不能少于3个字符!");
    			return false;
    		}
    		return true;
    	}
    	function onRename(e,treeId,treeNode,isCancel){
    		alert("修改节点的id为:"+treeNode.id+"
    修改后的名称为:"+treeNode.name);
    	}
    	function clickNode(e,treeId,treeNode){
    		if(treeNode.id == 11){
    			location.href=treeNode.url;
    		}else{
    			alert("节点名称:"+treeNode.name+"
    节点id:"+treeNode.id);
    		}
    	}
    	function beforeDrag(treeId,treeNodes){
    		return false;
    	}
    	var newCount = 1;
    	function addHoverDom(treeId,treeNode){
    		var sObj = $("#" + treeNode.tId + "_span");
    		if (treeNode.editNameFlag || $("#addBtn_"+treeNode.tId).length>0) return;
    		var addStr = "<span class='button add' id='addBtn_" + treeNode.tId
    			+ "' title='添加子节点' onfocus='this.blur();'></span>";
    		sObj.after(addStr);
    		var btn = $("#addBtn_"+treeNode.tId);
    		if (btn) btn.bind("click", function(){
    			//在这里向后台发送请求保存一个新建的叶子节点,父id为treeNode.id,让后将下面的100+newCount换成返回的id
    			//zTree.addNodes(treeNode, {id:(100 + newCount), pId:treeNode.id, name:"新建节点" + (newCount++)});
    			art.dialog({
    			    id: 'testID',
    			    content: '您想要添加同级节点还是子节点?',
    			    button: [
    			        {
    			            name: '同级节点',
    			            callback: function () {
    			            	if(!treeNode.isParent){
    			            		art.dialog({
    			            			content:'叶子节点不能建立同级节点',
    			            			ok:function(){}
    			            		});
    			            		return;
    			            	}
    			               var parentNode = treeNode.getParentNode();
    			               var pId = 0;
    			               if(parentNode != null){
    			            	   pId = parentNode.id;
    			               }
    			               zTree.addNodes(parentNode,{'id':(100+newCount),'pId':pId,'name':'新建同级节点','isParent':true});
    			            },
    			            focus: true
    			        },
    			        {
    			            name: '子节点',
    			            callback: function () {
    			            	zTree.addNodes(treeNode, {id:(100 + newCount), pId:treeNode.id, name:"新建子节点" + (newCount++)});
    			            },
    			            focus:true
    			        },
    			        {
    			            name: '取消'
    			        }
    			    ]
    			});
    			return false;
    		});
    	}
    	function removeHoverDom(treeId,treeNode){
    		$("#addBtn_"+treeNode.tId).unbind().remove();
    	}
    	</script>
    <body>
    	<ul id="tree" class="ztree"></ul>
    </body>
    </html>


     

    PS:如果引入了zTreeStyle.css,前面的加号小图标仍无法显示,需在改文件中添加:

    .ztree li span.button.add {margin-right:2px; background-position:-143px 0px; vertical-align:top; *vertical-align:middle}


     

  • 相关阅读:
    内存堆与栈的区别
    深度理解相对路径和绝对路径
    INFO:InstallAnywhere的Enterprise版本和Standard版本的主要区别
    HOWTO:InstallShield中如何调用批处理文件
    HOWTO:InstallScript工程中如何在用户协议界面中默认为接受协议
    HOWTO:InstallShield中如何通过脚本获取“My Documents”路径
    INFO:InstallShield工程中关于.NET依赖项的编译扫描警告
    InstallShield Kevin Wan博客文章索引列表(001~100)
    HOWTO:在InstallShield脚本中打开一个URL链接
    INFO:在InstallShield中修改安装包压缩.cab包的大小
  • 原文地址:https://www.cnblogs.com/bbsno1/p/3275586.html
Copyright © 2011-2022 走看看