用三种方式实现导航菜单中的二级下拉菜单

如何实现导航菜单栏中的二级下拉菜单?

  我们在淘宝、搜狐等大型网站上都可以看到使用的一些二级下拉菜单,比如下面这张图片。

但是如何实现类似的图片呢?实际上,我们有至少三种方式来实现,下面,我附上代码供大家参考。

1.仅使用html和css

<!DOCTYPE html>
<html lang="en">
<head>
	<meta charset="UTF-8">
	<title>Document</title>
	<style>
	*{margin:0;padding: 0;list-style: none;text-decoration: none;}
	#nav{width: 500px;height: 40px;background: #ccc;margin: 0 auto;}
	ul{background: #aaa}
	ul li{float:left; display:block; height: 40px; line-height: 40px; padding: 0 20px; position: relative;}
	ul li:hover{background: #cea;}
	ul li ul li{float: none;}
	/*关键一:将二级菜单设置为display:none;*/
	ul li ul{position: absolute;top:40px;left: 0; display: none;}
	ul li ul li:hover{background: red;}
	/*关键二:在划过二级菜单从属的一级菜单时,设置为display:block;*/
	ul li:hover ul{display: block;}
	</style>
</head>
<body>
	<div id="nav">
		<ul>
			<li><a href="">首页</a></li>
			<li><a href="">汽车</a>
				<ul>
					<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>
				</ul>
			</li>
			<li><a href="">联系我们</a></li>
		</ul>
	</div>
</body>
</html>

  我们可以看到,这种方法是比较好的,它保证了结构与表现的完全分离。

2.用javascript实现

<!DOCTYPE html>
<html lang="en">
<head>
	<meta charset="UTF-8">
	<title>Document</title>
	<style>
	*{margin:0;padding: 0;list-style: none;text-decoration: none;}
	#nav{width: 500px;height: 40px;background: #ccc;margin: 0 auto;}
	ul{background: #aaa}
	ul li{float:left; display:block; height: 40px; line-height: 40px; padding: 0 20px; position: relative;}
	ul li:hover{background: #cea;}
	ul li ul li{float: none;}
	ul li ul{position: absolute;top:40px;left: 0; display:none;}
	ul li ul li:hover{background: red;}
	</style>
</head>
<body>
	<div id="nav">
		<ul>
			<li><a href="#">首页</a></li>
			<li onmouseover="show(this)" onmouseout="hide(this)"><a href="#">汽车</a>
		<!-- 关键一:在二级标题从属的一级标题标签内设置时间执行程序,this代表的时这个li元素 -->
				<ul>
					<li><a href="#">奥迪</a> </li>
					<li><a href="#">道奇</a> </li>
				</ul>
			</li>
			<li onmouseover="show(this)" onmouseout="hide(this)"><a href="#">手机</a>
				<ul>
					<li><a href="#">小米</a> </li>
					<li><a href="#">华为</a> </li>
				</ul>
			</li>
			<li><a href="#">联系我们</a></li>
		</ul>
	</div>
	<script>
		function show(li){
			var ul=li.getElementsByTagName("ul")[0];
			 // 关建二:在li这个对象内查询标签名为ul的标签,由于二级标签只有一个,所以索引为0即可。
			ul.style.display="block";
			// 关键三:当鼠标划过li时,其子元素ul标签的display为block
		}
		function hide(li){
			var ul=li.getElementsByTagName("ul")[0];
			ul.style.display="none";
			// 关键四:当鼠标划出li时,其子元素ul的display为none
		}
	</script>
</body>
</html>

使用javascript实现起来较为麻烦,且这里结构和行为没有分开(虽然可以试用dom在JavaScript中创建使得结构和行为分开,但十分繁琐),不推荐。

3.用jQuery实现

  jQuery是一种javascript库,我们可以在jQuery官网上下载最新版本的库文件,其中压缩的文件是用于产品的,为压缩的文件是便于开发人员学习和调试的。下载到本机以后,需要将库文件引用到html中,由于jQuery本质上也是JavaScript,所以引用方式为:

    <script src="路径名称"></script>

用jQuery实现二级下拉菜单的代码如下:

<!DOCTYPE html>
<html lang="en">
<head>
	<meta charset="UTF-8">
	<title>Document</title>
	<style>
	*{margin:0;padding: 0;list-style: none;text-decoration: none;}
	#nav{width: 500px;height: 40px;background: #ccc;margin: 0 auto;}
	ul{background: #aaa}
	ul li{float:left; display:block; height: 40px; line-height: 40px; padding: 0 20px; position: relative;}
	ul li:hover{background: #cea;}
	ul li ul li{float: none;}
	ul li ul{position: absolute;top:40px;left: 0; display: none;}
	ul li ul li:hover{background: red;}
	</style>
</head>
<body>
	<div id="nav">
		<ul>
			<li><a href="">首页</a></li>
			<li class="navmenu"><a href="">汽车</a>
				<ul>
					<li><a href="#">奥迪</a> </li>
					<li><a href="#">道奇</a> </li>
				</ul>
			</li>
			<li class="navmenu"><a href="">手机</a>
				<ul>
					<li><a href="#">小米</a> </li>
					<li><a href="#">华为</a> </li>
				</ul>
			</li>
			<li><a href="">联系我们</a></li>
		</ul>
	</div>
	<script src="jquery-3.1.1.js"></script>
	<!-- 关键一:引入jQuery库文件 -->
	<script type="text/javascript">
		$(function(){
			$(".navmenu").mouseover(function(){
				$(this).children("ul").show();
			})

		})
	// 关键二:正确使用jQuey的语法完成行为。
		$(function(){
			$(".navmenu").mouseout(function(){
				$(this).children("ul").hide();
			})

		})
	</script>
</body>
</html>

 显然,使用jQuery是非常方便的。

最终的实现效果如下;

即当鼠标划过一级菜单时,会出现相应的二级菜单。

  如果大家希望学习关于菜单更多的知识,可以来慕课网学习。

  身不饥寒,天未曾负我;学无长进,我何以对天!

  

时间: 2024-12-26 20:40:27

用三种方式实现导航菜单中的二级下拉菜单的相关文章

如何实现导航菜单栏中的二级下拉菜单?

我们在淘宝.搜狐等大型网站上都可以看到使用的一些二级下拉菜单,比如下面这张图片. 但是如何实现类似的图片呢?实际上,我们有至少三种方式来实现,下面,我附上代码供大家参考. 1.仅使用html和css 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 <meta charset="UTF-8"> <title>Documen

航菜单栏中的二级下拉菜单

1.仅使用html和css <!DOCTYPE html><html><head><style>*{margin:0;padding: 0;list-style: none;text-decoration: none;}#nav{width: 600px;height: 40px;background: #ccc;margin: 0 auto;}ul{background: #aaa}ul li{float:left; display:block; heig

CSS3实现的横向二级下拉菜单代码实例

CSS3实现的横向二级下拉菜单代码实例:横向二级下拉菜单是非常常用的效果,例如很多网站的导航栏就是这样的二级下拉菜单效果,非常好用,本章节分享一段使用CSS3实现的下拉菜单,当然当下很多浏览器都不支持,不过相信用不了多久这种现状就会被改变.代码实例如下: <!DOCTYPE html> <html> <head> <meta charset="utf-8"> <meta name="author" content

InfoPath与SharePoint之(三) 在InfoPath中实现联动下拉菜单

在InfoPath中实现联动的下拉菜单是一种比较常见的需求.这里通过演示如何选择省份和城市,讲解一下如何实现联动下拉菜单. 首先在上一篇博客里建的Area List,再加一个City的column,类型就是Single Line of Text. 在上一篇的博客中创建的下拉菜单旁边,再添加一个,用来显示城市.这个时候两个下拉菜单是没有关联的,而且显示的都是全部的item. 为了方便区分,去把两个Drop-Down List改了名词,分别是Province 和City. 首先我们要去除掉省份的重复

Bootstrap中的各种下拉菜单

@*基本下拉菜单与按钮下拉菜单的样式完全一致.不过,基本的下拉菜单使用<div class="dropdown">包裹,所有要换行.而按钮式下拉菜单<div class="btn-group">按钮组包裹,属于内联样式,不换行. 分割的按钮下拉菜单多了一个<button></button>作为默认选项,另一个button的内容是<span class="caret">. 而<li

行内/块级垂直居中、图像文本替换以及二级下拉菜单的制作

经过近一个月对HTML与css的学习,利用HTML以及div+css对简单的静态网页进行简单的布局有了一定的基础,但是对于网页结构布局的分析.部分属性的使用存在着问题,希望在以后的学习能有所提高,这里就最近的学习情况进行一下总结与归纳: 一.行内元素与块级元素水平.垂直居中问题 (一)CSS设置行内元素的水平居中 div{text-align:center} /*DIV内的行内元素均会水平居中*/ CSS设置行内元素的垂直居中 div{height:30px; line-height:30px}

CSS+JS下拉菜单和纯CSS下拉菜单

一.CSS+JS下拉菜单 原理:一级菜单的li中包含二级菜单ul.在鼠标没有移上去时,二级菜单的ul是display:none的状态,鼠标一移上去变成display:block.改变这个display属性值是通过JS来实现.鼠标hover时,把整个二级菜单的ul给display出来,用到的事件onmouseonver.鼠标移出又把整个二级菜单的ul 给隐藏掉. nav-js.html文件 <!DOCTYPE html > <html> <head> <meta c

纯CSS3实现宽屏二级下拉菜单

今天我们要来分享一款基于纯CSS3的宽屏二级下拉菜单,这款菜单的子菜单在展开的时候是很宽敞的,菜单项中可以自定义格式的内容,非常实用,也很大气.由于是用纯CSS3实现,所以这款下拉菜单不用运行Javascript,展示速度当然是非常快的. 在线预览   源码下载

纯CSS实现的二级下拉菜单效果代码实例

纯CSS实现的二级下拉菜单效果代码实例:二级下拉是最为常用的效果之一,当前的此效果一般哟结合js实现,本章节介绍一个使用纯CSS实现的二级下拉菜单效果,希望能够给需要的朋友带来一定的帮助,不过此代码也有一点浏览器兼容问题,那就是在IE6中不兼容.代码如下: <!DOCTYPE html> <html> <head> <meta charset="utf-8"> <meta name="author" conten