zoukankan      html  css  js  c++  java
  • Ztree手风琴效果(第三版)

    第一版:点击一级目录展开,再点击时不能收回

    第二版:点击一级目录展开,再点击时可以收回

    第三版:优化样式,修复主菜单下的子菜单下级无子节点时点击无反应问题(js报错)

    <%@ page language="java" import="java.util.*" pageEncoding="UTF-8"%>
    <%
    String path = request.getContextPath();
    String basePath = request.getScheme()+"://"+request.getServerName()+":"+request.getServerPort()+path+"/";
    %>
    
    <!DOCTYPE html>
    <html>
    <head>
    	<title> ZTREE STYLE </title>
    	<meta http-equiv="content-type" content="text/html; charset=UTF-8">
    	<link rel="stylesheet" href="css/zTreeStyle.css" type="text/css">
    	<script type="text/javascript" src="js/jquery-1.9.1.min.js"></script>
    	<script type="text/javascript" src="js/jquery.ztree.core.js"></script>
    	<script type="text/javascript">
    		var curMenu = null, zTree_Menu = null;
    		var setting = {
    			view: {
    				showLine: false,
    				selectedMulti: false,
    				dblClickExpand: false,
    				expandSpeed: 500
    			},
    			data: {
    				simpleData: {
    					enable: true
    				}
    			},
    			callback: {
    				onNodeCreated: this.onNodeCreated,
    				beforeClick: this.beforeClick,
    				onClick: this.onClick
    			}
    		};
    
    		var zNodes =[
    			{ id:1, pId:0, name:"主菜单 1", open:true},
    			{ id:11, pId:1, name:"子菜单 1-1"},
    			/* { id:111, pId:11, name:"叶子节点 1-1-1"},
    			{ id:112, pId:11, name:"叶子节点 1-1-2"},
    			{ id:113, pId:11, name:"叶子节点 1-1-3"},
    			{ id:114, pId:11, name:"叶子节点 1-1-4"}, */
    			{ id:12, pId:1, name:"子菜单 1-2"},
    			{ id:121, pId:12, name:"叶子节点 1-2-1"},
    			{ id:122, pId:12, name:"叶子节点 1-2-2"},
    			{ id:123, pId:12, name:"叶子节点 1-2-3"},
    			{ id:124, pId:12, name:"叶子节点 1-2-4"},
    			{ id:2, pId:0, name:"主菜单 2"},
    			{ id:21, pId:2, name:"子菜单 2-1"},
    			{ id:211, pId:21, name:"叶子节点 2-1-1"},
    			{ id:212, pId:21, name:"叶子节点 2-1-2"},
    			{ id:213, pId:21, name:"叶子节点 2-1-3"},
    			{ id:214, pId:21, name:"叶子节点 2-1-4"},
    			{ id:22, pId:2, name:"子菜单 2-2"},
    			{ id:221, pId:22, name:"叶子节点 2-2-1"},
    			{ id:222, pId:22, name:"叶子节点 2-2-2"},
    			{ id:223, pId:22, name:"叶子节点 2-2-3"},
    			{ id:224, pId:22, name:"叶子节点 2-2-4"},
    			{ id:3, pId:0, name:"主菜单 3"},
    			{ id:31, pId:3, name:"子菜单 3-1"},
    			{ id:311, pId:31, name:"叶子节点 3-1-1"},
    			{ id:312, pId:31, name:"叶子节点 3-1-2"},
    			{ id:313, pId:31, name:"叶子节点 3-1-3"},
    			{ id:314, pId:31, name:"叶子节点 3-1-4"},
    			{ id:32, pId:3, name:"子菜单 3-2"},
    			{ id:321, pId:32, name:"叶子节点 3-2-1"},
    			{ id:322, pId:32, name:"叶子节点 3-2-2"},
    			{ id:323, pId:32, name:"叶子节点 3-2-3"},
    			{ id:324, pId:32, name:"叶子节点 3-2-4"}			
    		];
    
    		function beforeClick(treeId, node) {
    			var flag = node.open;
    			if (node.isParent) {
    				if (node.level === 0) {
    					var pNode = curMenu;
    					while (pNode && pNode.level !==0) {
    						pNode = pNode.getParentNode();
    					}
    					if (pNode !== node && pNode!= null) {
    						var a = $("#" + pNode.tId + "_a");
    						a.removeClass("cur");
    						zTree_Menu.expandNode(pNode, false);
    					}
    					a = $("#" + node.tId + "_a");
    					a.addClass("cur");
    
    					var isOpen = false;
    					for (var i=0,l=node.children.length; i<l; i++) {
    						if(node.children[i].open) {
    							isOpen = true;
    							break;
    						}
    					}
    					if (isOpen) {
    						zTree_Menu.expandNode(node, true);
    						curMenu = node;
    					} else {
    						zTree_Menu.expandNode(node.children[0].isParent?node.children[0]:node, true);
    						curMenu = node.children[0];
    					}
    					if (flag) {
    						zTree_Menu.expandNode(node, false);
    					} else {
    						zTree_Menu.expandNode(node, true);
    					}
    				} else {
    					zTree_Menu.expandNode(node);
    				}
    			}
    			return !node.isParent;
    		}
    		function onClick(e, treeId, node) {
    			alert("Do what you want to do!");
    		}
    
    		$(document).ready(function(){
    			$.fn.zTree.init($("#treeDemo"), setting, zNodes);
    			zTree_Menu = $.fn.zTree.getZTreeObj("treeDemo");
    			if(zTree_Menu.getNodes()[0].children[0].hasOwnProperty("children")){
    				curMenu = zTree_Menu.getNodes()[0].children[0].children[0];
    			}else{
    				curMenu = zTree_Menu.getNodes()[0].children[0];
    			}
    			zTree_Menu.selectNode(curMenu);
    			var a = $("#" + zTree_Menu.getNodes()[0].tId + "_a");
    			a.addClass("cur");
    		});
    	</script>
    	<style type="text/css">
    		.ztree li a.level0 {
    			100%;
    			height: 30px; 
    			text-align: center; 
    			display:block; 
    			/* background-color: #0B61A4;  */
    			border-bottom:1px silver solid;
    			text-decoration:none;
    		}
    		
    		.ztree li a.level0.cur {
    			/* background-color: #66A3D2; */
    		}
    		
    		.ztree li a.level0 span {
    			display: block; 
    			font-family:"微软雅黑", "宋体", Arial, sans-serif;
    			font-size:14px; 
    			font-weight: bold;
    			word-spacing:2px;
    			line-height:26px;
    		}
    		
    		.ztree li a.level0 span.button {	
    			float:right; 
    			visibility: visible;
    			display:none;
    		}
    		
    		.ztree li span.button.switch.level0 {
    			display:none;
    		}
    	</style>
     </head>
    
    <body>
    	<div style="100%; height:500px">
    		<div style="20%; height:100%; border:1px silver solid">
    			<ul id="treeDemo" class="ztree"></ul>
    		</div>
    	</div>
    </body>
    </html>
    
  • 相关阅读:
    eharts入门篇一
    手机侧滑导航栏
    用js+cookie实现商城的购物车功能
    实现文字底部居中
    超出两行或三行显示省略号
    clear-fix清除浮动的两种写法
    sass学习入门篇(三)
    如何回答面试中问到的Hibernate和MyBatis的区别
    设计模式之--单例模式
    设计模式之---工厂模式
  • 原文地址:https://www.cnblogs.com/henuyuxiang/p/6247436.html
Copyright © 2011-2022 走看看