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

纵向、横向导航菜单及二级弹出菜单一、纵向导航菜单及二级弹出菜单首先在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>

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

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

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

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

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • Binder 机制「建议收藏」

    Binder是Android系统进程间通信(IPC:InternetProcessConnection)方式之一。Linux已经拥有的IPC手段包括:管道(Pipe)、信号(Signal)、跟踪(Trace)、插口(Socket)、报文队列(Message)、共享内存(ShareMemory)和信号量(Semaphore)等。本文详细分析Binder作为Android主要IPC方式的优势。一、概述基于Client-Server的通信方式,广泛应用于从互联网和数据库访问

    2022年4月7日
    103
  • Android中如何使用单选对话框[通俗易懂]

    Android中如何使用单选对话框[通俗易懂]给Button设置OnClick事件设置intid=0;finalString[]s={“单选A”,”单选B”,”单选C”,”单选D”,”单选E”};AlertDialog.BuilderDanItem=newAlertDialog.Builder(MainActivity.this);DanItem.setTitle(“单选列表”);…

    2022年5月30日
    34
  • linux命令 dstat,dstat命令

    linux命令 dstat,dstat命令dstat命令是一个用来替换vmstat、iostat、netstat、nfsstat和ifstat这些命令的工具,是一个全能系统信息统计工具。与sysstat相比,dstat拥有一个彩色的界面,在手动观察性能状况时,数据比较显眼容易观察;而且dstat支持即时刷新,譬如输入dstat3即每三秒收集一次,但最新的数据都会每秒刷新显示。和sysstat相同的是,dstat也可以收集指定的性能资源,…

    2022年6月18日
    25
  • phpstorm2021 通过 github 激活破解方法

    phpstorm2021 通过 github 激活破解方法,https://javaforall.net/100143.html。详细ieda激活码不妨到全栈程序员必看教程网一起来了解一下吧!

    2022年3月15日
    98
  • jsoncpp官方教程_jsoncpp用法

    jsoncpp官方教程_jsoncpp用法本文主要介绍使用JsonCpp库,通过C++编程语言实现JSON文件读写操作的具体方法。1写入JSON文件这里编写一个示例程序,该程序将JSON字符串写入到JSON文件中。示例代码(json_file_oper_write.cpp)的内容如下:#include<jsoncpp/json/json.h>#include<fstream>usingnamespacestd;intmain(){Json::Value

    2022年10月10日
    0
  • Arduino编程之Serial.println()和Serial.print()

    Arduino编程之Serial.println()和Serial.print()Arduino编程之Serial.println()和Serial.print()Arduino的输出基本就用两个函数print和println,区别在于后者比前者多了回车换行Serial.println(data)从串行端口输出数据,跟随一个回车(ASCII13,或’r’)和一个换行符(ASCII10,或’n’)。这个函数所取得的值与Serial.print()一样。Ser…

    2022年10月3日
    0

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

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