纵向、横向导航菜单及二级弹出菜单

纵向、横向导航菜单及二级弹出菜单一、纵向导航菜单及二级弹出菜单首先在body中添加一个div标签,其中包含ulliul的标签结构存放网站菜单,效果如下:<%@pagelanguage="java"import="java.util.*"pageEncoding="UTF-8"%><%Stringpath=request.getContextPath();StringbasePath=…

大家好,又见面了,我是你们的朋友全栈君。如果您正在找激活码,请点击查看最新教程,关注关注公众号 “全栈程序员社区” 获取激活教程,可能之前旧版本教程已经失效.最新Idea2022.1教程亲测有效,一键激活。

Jetbrains全系列IDE使用 1年只要46元 售后保障 童叟无欺

一、纵向导航菜单及二级弹出菜单

首先在body中添加一个div标签,其中包含ulli ul的标签结构存放网站菜单,效果如下:

<%@ page language="java" import="java.util.*" 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">
<html>
  <head>
    <base href="<%=basePath%>">
    <title>My JSP 'demo4.jsp' starting page</title>
	<meta http-equiv="pragma" content="no-cache">
	<meta http-equiv="cache-control" content="no-cache">
	<meta http-equiv="expires" content="0">    
	<meta http-equiv="keywords" content="keyword1,keyword2,keyword3">
	<meta http-equiv="description" content="This is my page">
  </head>
  <body>
    <div id="menu">
    	<ul>
    		<li><a href="#" target="blank">首页</a></li>
    		<li><a href="#">赛事指南</a>
    			<ul>
		    		<li><a href="#">竞赛规程</a></li>
		    		<li><a href="#">报名须知</a></li>
		    		<li><a href="#">参赛声明</a></li>
		    		<li><a href="#">比赛路线</a></li>
		    	</ul>
		    </li>		
    		<li><a href="#">赛事介绍</a>
    			<ul>
    				<li><a href="#">赛事简介</a></li>
	    			<li><a href="#">特色活动</a></li>
	    			<li><a href="#">精彩回顾</a></li>
    			</ul>
    		</li>
    		<li><a href="#">赛事报名</a>
    			<ul>
    				<li><a href="#">我的报名</a></li>
		    		<li><a href="#">号码查询</a></li>
		    		<li><a href="#">成绩查询</a></li>
		    		<li><a href="#">证书查询</a></li>
		    		<li><a href="#">照片查询</a></li>
    			</ul>
    		</li>	
    		<li><a href="#">合作伙伴</a>
    			<ul>
    				<li><a href="#">冠名赞助商</a></li>
		    		<li><a href="#">官方赞助商</a></li>
		    		<li><a href="#">赛事支持商</a></li>
		    		<li><a href="#">公益合作伙伴</a></li>
		    		<li><a href="#">合作媒体</a></li>
    			</ul>
    		</li>	
    	</ul>
    </div>
  </body>
</html>

纵向、横向导航菜单及二级弹出菜单

图中效果是标签自带的样式,现在需要先将默认样式清除,再添加自己的样式,在Head标签中添加css代码:

<style type="text/css">
	/*设置body中字体样式*/
	body{font-family:verdana;font-size:12px;line-height:1.5;}
	/*设置菜单样式*/
	#menu{width:100px;border:1px solid #CCC;}
	#menu ul{list-style:none;margin:0;padding:0;}
	/*重新设置超链接的样式*/
	a{color:#000;text-decoration:none;}
	/*设置鼠标悬浮超链接上时改变字体颜色*/
	a:hover{color:#F00;}
</style>

纵向、横向导航菜单及二级弹出菜单

下面是将同一子菜单下的菜单移动位置变为父级菜单的一部分,这里需要用到position属性。

1.position:relative;如果对一个元素进行相对定位,首先它将出现在它所在的位置上。然后通过设置垂直或水平位置,让这个元素”相对于”它的原始起点进行移动。(再一点,相对定位时,无论是否进行移动,元素仍然占据原来的空间。因此,移动元素会导致它覆盖其他框)

2.position:absolute;表示绝对定位,位置将依据浏览器左上角开始计算。 绝对定位使元素脱离文档流,因此不占据空间。普通文档流中元素的布局就像绝对定位的元素不存在时一样。(因为绝对定位的框与文档流无关,所以它们可以覆盖页面上的其他元素并可以通过z-index来控制它层级次序。z-index的值越高,它显示的越在上层。)

3.父容器使用相对定位,子元素使用绝对定位后,这样子元素的位置不再相对于浏览器左上角,而是相对于父窗口左上角。

4.相对定位和绝对定位需要配合top、right、bottom、left使用来定位具体位置,这四个属性只有在该元素使用定位后才生效,其它情况下无效。另外这四个属性同时只能使用相邻的两个,不能即使用上又使用下,或即使用左,又使用右。

我们要实现的效果是子菜单不占据空间,所以可以使用position:absolute;让子元素脱离文档流,使用left和top属性确定子菜单相对于父级菜单的位置。然后父级菜单使用position:relative;来固定在文档流中。

/*设置父级菜单样式*/
#menu ul li{background:#eee;padding:0px 7px;height:25px;line-height:25px;border-bottom:1px solid #CCC;position:relative;}
/*设置子菜单样式*/
#menu ul li ul{display:none;position:absolute;left:100px;top:0px;width:100px;border:1px solid #CCC;}

这里由于需要隐藏和显示子菜单,所以涉及到display属性。

display:none;不显示元素

display:block;可以将行内标签变为块标签,占据一行

display:inline;可以将块标签变为行内标签,占据一行内的一部分位置

我们需要实现,当鼠标悬浮到父级菜单上时显示子菜单,当鼠标离开父级菜单时隐藏子菜单,因此可以使用display的none属性隐藏菜单,当鼠标移动到父级菜单上时使用display:block显示菜单。

纵向、横向导航菜单及二级弹出菜单

/*鼠标移动到父级菜单时显示子菜单*/
#menu ul li:hover ul{display:block;}

纵向、横向导航菜单及二级弹出菜单

最后的页面代码如下:

<%@ page language="java" import="java.util.*" 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">
<html>
  <head>
    <base href="<%=basePath%>">
    <title>My JSP 'demo4.jsp' starting page</title>
	<meta http-equiv="pragma" content="no-cache">
	<meta http-equiv="cache-control" content="no-cache">
	<meta http-equiv="expires" content="0">    
	<meta http-equiv="keywords" content="keyword1,keyword2,keyword3">
	<meta http-equiv="description" content="This is my page">
	<style type="text/css">
		/*设置body中字体样式*/
		body{font-family:verdana;font-size:12px;line-height:1.5;}
		/*设置菜单样式*/
		#menu{width:100px;border:1px solid #CCC;}
		#menu ul{list-style:none;margin:0;padding:0;}
		/*重新设置超链接的样式*/
		a{color:#000;text-decoration:none;}
		/*设置鼠标悬浮超链接上时改变字体颜色*/
		a:hover{color:#F00;}
		/*设置父级菜单样式*/
		#menu ul li{background:#eee;padding:0px 7px;height:25px;line-height:25px;border-bottom:1px solid #CCC;position:relative;}
		/*设置子菜单样式*/
		#menu ul li ul{display:none;position:absolute;left:100px;top:0px;width:100px;border:1px solid #CCC;}
		/*鼠标移动到父级菜单时显示子菜单*/
		#menu ul li:hover ul{display:block;}
	</style>
  </head>
  <body>
    <div id="menu">
    	<ul>
    		<li><a href="#" target="blank">首页</a></li>
    		<li><a href="#">赛事指南</a>
    			<ul>
		    		<li><a href="#">竞赛规程</a></li>
		    		<li><a href="#">报名须知</a></li>
		    		<li><a href="#">参赛声明</a></li>
		    		<li><a href="#">比赛路线</a></li>
		    	</ul>
		    </li>		
    		<li><a href="#">赛事介绍</a>
    			<ul>
    				<li><a href="#">赛事简介</a></li>
	    			<li><a href="#">特色活动</a></li>
	    			<li><a href="#">精彩回顾</a></li>
    			</ul>
    		</li>
    		<li><a href="#">赛事报名</a>
    			<ul>
    				<li><a href="#">我的报名</a></li>
		    		<li><a href="#">号码查询</a></li>
		    		<li><a href="#">成绩查询</a></li>
		    		<li><a href="#">证书查询</a></li>
		    		<li><a href="#">照片查询</a></li>
    			</ul>
    		</li>	
    		<li><a href="#">合作伙伴</a>
    			<ul>
    				<li><a href="#">冠名赞助商</a></li>
		    		<li><a href="#">官方赞助商</a></li>
		    		<li><a href="#">赛事支持商</a></li>
		    		<li><a href="#">公益合作伙伴</a></li>
		    		<li><a href="#">合作媒体</a></li>
    			</ul>
    		</li>	
    	</ul>
    </div>
  </body>
</html>

二、横向导航菜单及二级菜单

横向菜单和纵向菜单类似

<%@ page language="java" import="java.util.*" 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">
<html>
  <head>
    <base href="<%=basePath%>">
    <title>My JSP 'Test.jsp' starting page</title>
	<meta http-equiv="pragma" content="no-cache">
	<meta http-equiv="cache-control" content="no-cache">
	<meta http-equiv="expires" content="0">    
	<meta http-equiv="keywords" content="keyword1,keyword2,keyword3">
	<meta http-equiv="description" content="This is my page">
	<style type="text/css">
		body{font-family:Verdana;font-size:15px;line-height:1.5;}
		a{color:#000;text-decoration:none;}
		a:hover{color:#F00;}
		#menu{border-bottom:3px solid #E10001;width:500px;height:25px;background:#eee;margin:0px auto;}
		#menu ul{list-style:none;margin:0px;padding:0px;}
		#menu ul li{float:left;margin-left:35px;}
		<!--将超链接设置成块元素更美观-->
		#menu ul li a{display:block;padding:0px auto;width:85px;height:25px;line-height:25px;text-align:center;font-size:15px;}
		#menu ul li a:hover{background:#333;color:#fff;}
		#menu ul li ul{border:1px solid #ccc;display:none;position:absolute;}
		#menu ul li ul li{float:none;width:95px;background:#eee;margin:0 auto;}
		#menu ul li ul li a{background:none;}
		#menu ul li ul li a:hover{background:#333;color:#fff;}
		#menu ul li:hover ul{display:block;}
	</style>
  </head>
  <body>
  	<div id="menu">
    	<ul>
    		<li><a href="#" target="blank">首页</a></li>
    		<li><a href="#">赛事指南</a>
    			<ul>
		    		<li><a href="#">竞赛规程</a></li>
		    		<li><a href="#">报名须知</a></li>
		    		<li><a href="#">参赛声明</a></li>
		    		<li><a href="#">比赛路线</a></li>
		    	</ul>
		    </li>		
    		<li><a href="#">赛事介绍</a>
    			<ul>
    				<li><a href="#">赛事简介</a></li>
	    			<li><a href="#">特色活动</a></li>
	    			<li><a href="#">精彩回顾</a></li>
    			</ul>
    		</li>
    		<li><a href="#">赛事报名</a>
    			<ul>
    				<li><a href="#">我的报名</a></li>
		    		<li><a href="#">号码查询</a></li>
		    		<li><a href="#">成绩查询</a></li>
		    		<li><a href="#">证书查询</a></li>
		    		<li><a href="#">照片查询</a></li>
    			</ul>
    		</li>	
    		<li><a href="#">合作伙伴</a>
    			<ul>
    				<li><a href="#">冠名赞助商</a></li>
		    		<li><a href="#">官方赞助商</a></li>
		    		<li><a href="#">赛事支持商</a></li>
		    		<li><a href="#">公益合作伙伴</a></li>
		    		<li><a href="#">合作媒体</a></li>
    			</ul>
    		</li>	
    	</ul>
    </div>
  </body>
</html>

纵向、横向导航菜单及二级弹出菜单

纵向、横向导航菜单及二级弹出菜单

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。

发布者:全栈程序员-用户IM,转载请注明出处:https://javaforall.cn/159464.html原文链接:https://javaforall.cn

【正版授权,激活自己账号】: Jetbrains全家桶Ide使用,1年售后保障,每天仅需1毛

【官方授权 正版激活】: 官方授权 正版激活 支持Jetbrains家族下所有IDE 使用个人JB账号...

(0)


相关推荐

发表回复

您的电子邮箱地址不会被公开。

关注全栈程序员社区公众号