第8章 利用CSS制作导航菜单

发布于:2024-12-06 ⋅ 阅读:(134) ⋅ 点赞:(0)

8.1 水平顶部导航栏

水平莱单导航栏是网站设计中应用范围最广的导航设计,一般放置在页面的顶部。水平
导航适用性强,几乎所有类型的网站都可以使用,设计难度较低。
如果导航过于普通,无法容纳复杂的信息结构,就需要在内容模块较多的情况下,结合
下拉子导航使用

8.1.1 简单水平导航栏的设计与实现

8.1.1.1 导航栏的创建

使用HTML的<nav>标签和<ul>/<li>列表结构来创建基本的导航栏

<!DOCTYPE html>
<html>
	<head>
		<meta charset="utf-8">
		<title></title>
	</head>
	<body>
		<center><h3>简单水平菜单导航栏</h3></center>
		<hr>
		<nav>
			<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>
				<li><a href="#">服务器</a></li>
			</ul>
		</nav>
	</body>
</html>

8.1.1.2 列表样式的设计

通过CSS去除列表的默认样式(如点号和缩进),并设置列表项的布局方式(如浮动或Flexbox)

<!DOCTYPE html>
<html>
	<head>
		<meta charset="utf-8">
		<title>水平导航栏的制作</title>
		<style type="text/css">
			/* 8.1.1.2 列表样式的设计 */
			li{
				float: left;
			}
			ul{
				list-style-type: none;
			}
		</style>
	</head>
	<body>
		<center><h3>简单水平菜单导航栏</h3></center>
		<hr>
		<nav>
			<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>
				<li><a href="#">服务器</a></li>
			</ul>
		</nav>
	</body>
</html>

8.1.1.3 超链接样式的设计 

设计导航链接的样式,包括颜色、字体、悬停效果等

<!DOCTYPE html>
<html>
	<head>
		<meta charset="utf-8">
		<title>水平导航栏的制作</title>
		<style type="text/css">
			/* 8.1.1.2 列表样式的设计 */
			li{
				float: left;
			}
			ul{
				list-style-type: none;
			}
			/* 8.1.1.3 超链接样式的设计 */
			a{
				text-decoration: none;
				display: block;
				width: 100px;
				padding: 10px;
				text-align: center;
			}
		</style>
	</head>
	<body>
		<center><h3>简单水平菜单导航栏</h3></center>
		<hr>
		<nav>
			<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>
				<li><a href="#">服务器</a></li>
			</ul>
		</nav>
	</body>
</html>

8.1.1.4 鼠标事件 

添加鼠标悬停和点击事件,以改变链接的外观或执行其他动作

<!DOCTYPE html>
<html>
	<head>
		<meta charset="utf-8">
		<title>水平导航栏的制作</title>
		<style type="text/css">
			/* 8.1.1.2 列表样式的设计 */
			li{
				float: left;
			}
			ul{
				list-style-type: none;
			}
			/* 8.1.1.3 超链接样式的设计 */
			a{
				text-decoration: none;
				display: block;
				width: 100px;
				padding: 10px;
				text-align: center;
			}
			/* 8.1.1.4 鼠标事件 */
			a:link,a:visited{
				background-color: #ff0000;
				color: #ffffff;
			}
			a:hover,a:active{
				background-color: #ffffff;
				color: #ff0000;
			}
		</style>
	</head>
	<body>
		<center><h3>简单水平菜单导航栏</h3></center>
		<hr>
		<nav>
			<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>
				<li><a href="#">服务器</a></li>
			</ul>
		</nav>
	</body>
</html>

8.1.2 下拉子菜单导航栏的设计与实现 

 8.1.2.1 导航栏的创建

同样使用<nav><ul>/<li>结构,但为某些列表项添加嵌套的<ul>以创建下拉子菜单。

<!--示例程序8.2-->
<!DOCTYPE html>
<html>
	<head>
		<meta charset="utf-8" />
		<title>下拉子导航栏的制作</title>
		<style type="text/css">
			/* 8.1.2.1导航栏的创建 */
			/* 8.1.2.2 列表样式的设计 */
			ul,ol{
				list-style-type: none;
				margin: 0;
				padding: 0;
			}
			ul li{
				float: left;
			}
			ul li ol li{
				float: none;
			}
			/* 8.1.2.3 二级菜单的隐藏和显示设计 */
			/* 8.1.2.4 DIV样式的设计 + 8.1.2.5 超链接样式的设计 */
			/* 8.1.2.6 鼠标事件 */
		</style>
	</head>
	<body>
		<center>
			<h3>下拉子菜单导航栏</h3>
		</center>
		<hr>
		<nav>
			<div id="nav">
				<ul>
					<li><a href="#">前端</a>
						<ol>
							<li><a href="#">HTML5</a></li>
							<li><a href="#">CSS</a></li>
							<li><a href="#">Javascript</a></li>
						</ol>
					</li>
					<li><a href="#">后台</a>
						<ol>
							<li><a href="#">Java</a></li>
							<li><a href="#">PHP</a></li>
							<li><a href="#">Python</a></li>
						</ol>
					</li>
					<li><a href="#">移动应用</a>
						<ol>
							<li><a href="#">Android</a></li>
							<li><a href="#">IOS</a></li>
						</ol>
					</li>
					<li><a href="#">数据库</a>
						<ol>
							<li><a href="#">MySql</a></li>
							<li><a href="#">SqlServer</a></li>
						</ol>
					</li>
					<li><a href="#">操作系统</a>
						<ol>
							<li><a href="#">Linux</a></li>
							<li><a href="#">Unix</a></li>
							<li><a href="#">Windows</a></li>
						</ol>
					</li>
					<li><a href="#">服务器</a>
						<ol>
							<li><a href="#">Tomcat</a></li>
							<li><a href="#">WebSphere</a></li>
							<li><a href="#">WebLogicc</a></li>
						</ol>
					</li>
				</ul>
			</div>
		</nav>
	</body>
</html>

8.1.2.2 列表样式的设计

除了基本样式外,还需设计子菜单的隐藏和显示方式

<!--示例程序8.2-->
<!DOCTYPE html>
<html>
	<head>
		<meta charset="utf-8" />
		<title>下拉子导航栏的制作</title>
		<style type="text/css">
			/* 8.1.2.1导航栏的创建 */
			/* 8.1.2.2 列表样式的设计 */
			ul,ol{
				list-style-type: none;
				margin: 0;
				padding: 0;
			}
			ul li{
				float: left;
			}
			ul li ol li{
				float: none;
			}
			/* 8.1.2.3 二级菜单的隐藏和显示设计 */
			ul li ol{
				display: none;
			}
			ul li:hover ol{
				display: block;
			}
			/* 8.1.2.4 DIV样式的设计 + 8.1.2.5 超链接样式的设计 */
			/* 8.1.2.6 鼠标事件 */
		</style>
	</head>
	<body>
		<center>
			<h3>下拉子菜单导航栏</h3>
		</center>
		<hr>
		<nav>
			<div id="nav">
				<ul>
					<li><a href="#">前端</a>
						<ol>
							<li><a href="#">HTML5</a></li>
							<li><a href="#">CSS</a></li>
							<li><a href="#">Javascript</a></li>
						</ol>
					</li>
					<li><a href="#">后台</a>
						<ol>
							<li><a href="#">Java</a></li>
							<li><a href="#">PHP</a></li>
							<li><a href="#">Python</a></li>
						</ol>
					</li>
					<li><a href="#">移动应用</a>
						<ol>
							<li><a href="#">Android</a></li>
							<li><a href="#">IOS</a></li>
						</ol>
					</li>
					<li><a href="#">数据库</a>
						<ol>
							<li><a href="#">MySql</a></li>
							<li><a href="#">SqlServer</a></li>
						</ol>
					</li>
					<li><a href="#">操作系统</a>
						<ol>
							<li><a href="#">Linux</a></li>
							<li><a href="#">Unix</a></li>
							<li><a href="#">Windows</a></li>
						</ol>
					</li>
					<li><a href="#">服务器</a>
						<ol>
							<li><a href="#">Tomcat</a></li>
							<li><a href="#">WebSphere</a></li>
							<li><a href="#">WebLogicc</a></li>
						</ol>
					</li>
				</ul>
			</div>
		</nav>
	</body>
</html>

8.1.2.4 DIV样式的设计

可能需要额外的<div>来包裹导航栏或子菜单,以便进行更精细的布局和样式控制

<!--示例程序8.2-->
<!DOCTYPE html>
<html>
	<head>
		<meta charset="utf-8" />
		<title>下拉子导航栏的制作</title>
		<style type="text/css">
			/* 8.1.2.1导航栏的创建 */
			/* 8.1.2.2 列表样式的设计 */
			ul,ol{
				list-style-type: none;
				margin: 0;
				padding: 0;
			}
			ul li{
				float: left;
			}
			ul li ol li{
				float: none;
			}
			/* 8.1.2.3 二级菜单的隐藏和显示设计 */
			ul li ol{
				display: none;
			}
			ul li:hover ol{
				display: block;
			}
			/* 8.1.2.4 DIV样式的设计 + 8.1.2.5 超链接样式的设计 */
			a{
				text-decoration: none;
				display: block;
				width: 100px;
				text-align: center;
				padding: 10px;
			}
			/* 8.1.2.6 鼠标事件 */
		</style>
	</head>
	<body>
		<center>
			<h3>下拉子菜单导航栏</h3>
		</center>
		<hr>
		<nav>
			<div id="nav">
				<ul>
					<li><a href="#">前端</a>
						<ol>
							<li><a href="#">HTML5</a></li>
							<li><a href="#">CSS</a></li>
							<li><a href="#">Javascript</a></li>
						</ol>
					</li>
					<li><a href="#">后台</a>
						<ol>
							<li><a href="#">Java</a></li>
							<li><a href="#">PHP</a></li>
							<li><a href="#">Python</a></li>
						</ol>
					</li>
					<li><a href="#">移动应用</a>
						<ol>
							<li><a href="#">Android</a></li>
							<li><a href="#">IOS</a></li>
						</ol>
					</li>
					<li><a href="#">数据库</a>
						<ol>
							<li><a href="#">MySql</a></li>
							<li><a href="#">SqlServer</a></li>
						</ol>
					</li>
					<li><a href="#">操作系统</a>
						<ol>
							<li><a href="#">Linux</a></li>
							<li><a href="#">Unix</a></li>
							<li><a href="#">Windows</a></li>
						</ol>
					</li>
					<li><a href="#">服务器</a>
						<ol>
							<li><a href="#">Tomcat</a></li>
							<li><a href="#">WebSphere</a></li>
							<li><a href="#">WebLogicc</a></li>
						</ol>
					</li>
				</ul>
			</div>
		</nav>
	</body>
</html>

8.1.2.5 超链接样式的设计

设计子菜单链接的样式,确保与主菜单链接风格一致或有所区分

<!--示例程序8.2-->
<!DOCTYPE html>
<html>
	<head>
		<meta charset="utf-8" />
		<title>下拉子导航栏的制作</title>
		<style type="text/css">
			/* 8.1.2.1导航栏的创建 */
			/* 8.1.2.2 列表样式的设计 */
			ul,ol{
				list-style-type: none;
				margin: 0;
				padding: 0;
			}
			ul li{
				float: left;
			}
			ul li ol li{
				float: none;
			}
			/* 8.1.2.3 二级菜单的隐藏和显示设计 */
			ul li ol{
				display: none;
			}
			ul li:hover ol{
				display: block;
			}
			/* 8.1.2.4 DIV样式的设计 + 8.1.2.5 超链接样式的设计 */
			a{
				text-decoration: none;
				display: block;
				width: 100px;
				text-align: center;
				padding: 10px;
			}
			ul li a{
				background-color: #ff0000;
				color: #eeeeee;
			}
			ul li ol a{
				background-color: #eeeeee;
				color: #ff0000;
			}
			/* 8.1.2.6 鼠标事件 */
		</style>
	</head>
	<body>
		<center>
			<h3>下拉子菜单导航栏</h3>
		</center>
		<hr>
		<nav>
			<div id="nav">
				<ul>
					<li><a href="#">前端</a>
						<ol>
							<li><a href="#">HTML5</a></li>
							<li><a href="#">CSS</a></li>
							<li><a href="#">Javascript</a></li>
						</ol>
					</li>
					<li><a href="#">后台</a>
						<ol>
							<li><a href="#">Java</a></li>
							<li><a href="#">PHP</a></li>
							<li><a href="#">Python</a></li>
						</ol>
					</li>
					<li><a href="#">移动应用</a>
						<ol>
							<li><a href="#">Android</a></li>
							<li><a href="#">IOS</a></li>
						</ol>
					</li>
					<li><a href="#">数据库</a>
						<ol>
							<li><a href="#">MySql</a></li>
							<li><a href="#">SqlServer</a></li>
						</ol>
					</li>
					<li><a href="#">操作系统</a>
						<ol>
							<li><a href="#">Linux</a></li>
							<li><a href="#">Unix</a></li>
							<li><a href="#">Windows</a></li>
						</ol>
					</li>
					<li><a href="#">服务器</a>
						<ol>
							<li><a href="#">Tomcat</a></li>
							<li><a href="#">WebSphere</a></li>
							<li><a href="#">WebLogicc</a></li>
						</ol>
					</li>
				</ul>
			</div>
		</nav>
	</body>
</html>

8.1.2.6 鼠标事件

为下拉子菜单添加鼠标悬停和点击事件,确保用户交互的流畅性

<!--示例程序8.2-->
<!DOCTYPE html>
<html>
	<head>
		<meta charset="utf-8" />
		<title>下拉子导航栏的制作</title>
		<style type="text/css">
			/* 8.1.2.1导航栏的创建 */
			/* 8.1.2.2 列表样式的设计 */
			ul,ol{
				list-style-type: none;
				margin: 0;
				padding: 0;
			}
			ul li{
				float: left;
			}
			ul li ol li{
				float: none;
			}
			/* 8.1.2.3 二级菜单的隐藏和显示设计 */
			ul li ol{
				display: none;
			}
			ul li:hover ol{
				display: block;
			}
			/* 8.1.2.4 DIV样式的设计 + 8.1.2.5 超链接样式的设计 */
			a{
				text-decoration: none;
				display: block;
				width: 100px;
				text-align: center;
				padding: 10px;
			}
			ul li a{
				background-color: #ff0000;
				color: #eeeeee;
			}
			ul li ol a{
				background-color: #eeeeee;
				color: #ff0000;
			}
			/* 8.1.2.6 鼠标事件 */
			ul li a:hover,ul li a:active{
				border-bottom: #aaccff solid 5px;
			}
			ul li ol li a:hover,ul li ol li a:active{
				border-bottom: none;
				background-color: #ff0000;
				color: #eeeeee;
			}
		</style>
	</head>
	<body>
		<center>
			<h3>下拉子菜单导航栏</h3>
		</center>
		<hr>
		<nav>
			<div id="nav">
				<ul>
					<li>前端
						<ol>
							<li>HTML5</li>
							<li>CSS</li>
							<li>Javascript</li>
						</ol>
					</li>
					<li>后台
						<ol>
							<li>Java</li>
							<li>PHP</li>
							<li>Python</li>
						</ol>
					</li>
					<li>移动应用
						<ol>
							<li>Android</li>
							<li>IOS</li>
						</ol>
					</li>
					<li>数据库
						<ol>
							<li>MySql</li>
							<li>SqlServer</li>
						</ol>
					</li>
					<li>操作系统
						<ol>
							<li>Linux</li>
							<li>Unix</li>
							<li>Windows</li>
						</ol>
					</li>
					<li>服务器
						<ol>
							<li>Tomcat</li>
							<li>WebSphere</li>
							<li>WebLogicc</li>
						</ol>
					</li>
				</ul>
			</div>
		</nav>
	</body>
</html>

 

8.2 纵向侧边导航栏

 侧边菜单导航栏是网站设计中应用频率仅次于水平导航栏的导航设计,一般放置在首页的左上角,普遍使用文字链接作为导航项,可以容纳很多链接

8.2.1 简单纵向导航栏的设计与实现
8.2.1.1 导航栏的创建

使用<nav>和垂直排列的<ul>/<li>结构

<!DOCTYPE html>
<html>
	<head>
		<meta charset="utf-8">
		<title>纵向导航栏的作用</title>
		<style type="text/css">
			/* 8.2.1.1导航栏的创建 */
			div{
				background-color: #33cc00;
				width: 150px;
				padding: 10px;
			}
		</style>
	</head>
	<body>
		<nav>
			<div id="nav">
				<h3>所有商品分类</h3>
				<ul>
					<li>家居用品</li>
					<li>手机数码</li>
					<li>家用电器</li>
					<li>厨卫工具</li>
					<li>汽车用品</li>
					<li>运动器材</li>
				</ul>
			</div>
		</nav>
	</body>
</html>

8.2.1.2 DIV样式的设计

可能使用<div>来包裹导航栏,以便进行布局和样式调整

<!DOCTYPE html>
<html>
	<head>
		<meta charset="utf-8">
		<title>纵向导航栏的作用</title>
		<style type="text/css">
			/* 8.2.1.1导航栏的创建 */
			div{
				background-color: #33cc00;
				width: 150px;
				padding: 10px;
			}
           /* 8.2.1.2 DIV样式的设计 */
			h3{
				color: #eeeeee;
				text-align: center;
			}
		</style>
	</head>
	<body>
		<nav>
			<div id="nav">
				<h3>所有商品分类</h3>
				<ul>
					<li>家居用品</li>
					<li>手机数码</li>
					<li>家用电器</li>
					<li>厨卫工具</li>
					<li>汽车用品</li>
					<li>运动器材</li>
				</ul>
			</div>
		</nav>
	</body>
</html>

8.2.1.3 列表样式的设计

设置列表项为垂直排列,并去除默认样式

<!DOCTYPE html>
<html>
	<head>
		<meta charset="utf-8">
		<title>纵向侧边导航栏</title>
		<style type="text/css">
			#nav{
				width: 150px;
				background-color: #aaccff;
				}
				h3{
					text-align: center;
					line-height: 50px;
				}
				ul{
					margin: 0;
					padding: 0;
					list-style-type: none;
				}
				ul li{
					line-height: 40px;
					border: #aaffff solid 2px;
					text-align: center;
				}
		</style>
	</head>
	<body>
		<nav>
			<div id="nav">
				<h3 class="tit">所以商品分类</h3>
				<ul>
					<li><a>家具用品</a></li>
					<li><a>手机数码</a></li>
					<li><a>家用电器</a></li>
					<li><a>厨卫工具</a></li>
					<li><a>汽车用品</a></li>
					<li><a>运动器材</a></li>
				</ul>
			</div>
		</nav>
	</body>
</html>

8.2.1.4 超链接样式的设计

设计纵向导航链接的样式

8.2.2 出式子菜单导航栏的设计与实现
8.2.2.1 导航栏的创建

与简单纵向导航栏类似,但包含嵌套的<ul>以创建出式子菜单

<!--示例程序8.4-->
<!DOCTYPE html>
<html>
	<head>
		<meta charset="utf-8" />
		<title>出式子导航栏的制作</title>
		<style type="text/css">
			/* 8.2.2.1 导航栏的创建 */
			/* 8.2.2.2 DIV样式的设计 */
			div{
				background-color: #33cc00;
				width: 150px;
				padding: 10px;
			}
			h3{
				color: #eeeeee;
				text-align: center;
			}
		</style>
	</head>
	<body>
		<nav>
			<div id="nav">
				<h3 class="tit">所有商品分类</h3>
				<ul>
					<li><a href="#">家居用品<img src="img/more.JPG" align="right" /></a>
						<ol>
							<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>
						</ol>
					</li>
					<li><a href="#">手机数码<img src="img/more.JPG" align="right" /></a>
						<ol>
							<li><a href="#">电脑主机</a></li>
							<li><a href="#">鼠标键盘</a></li>
							<li><a href="#">无人机</a></li>
							<li><a href="#">数码相机</a></li>
						</ol>
					</li>
					<li><a href="#">家用电器<img src="img/more.JPG" align="right" /></a>
						<ol>
							<li><a href="#">吸尘器</a></li>
							<li><a href="#">电饭煲</a></li>
							<li><a href="#">冰箱</a></li>
						</ol>
					</li>
					<li><a href="#">厨卫工具<img src="img/more.JPG" align="right" /></a>
						<ol>
							<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>
						</ol>
					</li>
					<li><a href="#">汽车用品<img src="img/more.JPG" align="right" /></a>
						<ol>
							<li><a href="#">打蜡服务</a></li>
							<li><a href="#">超级试驾</a></li>
							<li><a href="#">导航仪</a></li>
							<li><a href="#">机油</a></li>
						</ol>
					</li>
					<li><a href="#">运动器材<img src="img/more.JPG" align="right" /></a>
						<ol>
							<li><a href="#">跑鞋</a></li>
							<li><a href="#">帐篷</a></li>
							<li><a href="#">山地车</a></li>
						</ol>
					</li>
				</ul>
			</div>
		</nav>
	</body>
</html>

8.2.2.3  二级菜单的隐藏和显示设计

使用CSS或JavaScript控制子菜单的显示和隐藏

<!DOCTYPE html>
<html>
	<head>
		<meta charset="utf-8" />
		<title>出式子导航栏的制作</title>
		<style type="text/css">
			/* 8.2.2.1 导航栏的创建 */
			/* 8.2.2.2 DIV样式的设计 */
			div{
				background-color: #33cc00;
				width: 150px;
				padding: 10px;
			}
			h3{
				color: #eeeeee;
				text-align: center;
				
			}
			/* 8.2.2.4 列表样式的设计 */
			ul, ol{
				list-style-type: none;
				margin: 0;
				padding: 0;
			}
			/* 8.2.2.3 二级菜单的隐藏和显示设计 */
			ul li ol{
				display: none;
			}
			ul li:hover ol{
				display: block;
			}
		</style>
	</head>
	<body>
		<nav>
			<div id="nav">
				<h3 class="tit">所有商品分类</h3>
				<ul>
					<li>家居用品<img src="img/more.JPG" align="right" />
						<ol>
							<li>收纳箱</li>
							<li>雨伞雨具</li>
							<li>家务清洁</li>
							<li>茶具</li>
							<li>环保袋</li>
						</ol>
					</li>
					<li>手机数码<img src="img/more.JPG" align="right" />
						<ol>
							<li>电脑主机</li>
							<li>鼠标键盘</li>
							<li>无人机</li>
							<li>数码相机</li>
						</ol>
					</li>
					<li>家用电器<img src="img/more.JPG" align="right" />
						<ol>
							<li>吸尘器</li>
							<li>电饭煲</li>
							<li>冰箱</li>
						</ol>
					</li>
					<li>厨卫工具<img src="img/more.JPG" align="right" />
						<ol>
							<li>消毒柜</li>
							<li>抽油烟机</li>
							<li>碗柜</li>
							<li>花洒笼头</li>
							<li>洗手台</li>
						</ol>
					</li>
					<li>汽车用品<img src="img/more.JPG" align="right" />
						<ol>
							<li>打蜡服务</li>
							<li>超级试驾</li>
							<li>导航仪</li>
							<li>机油</li>
						</ol>
					</li>
					<li>运动器材<img src="img/more.JPG" align="right" />
						<ol>
							<li>跑鞋</li>
							<li>帐篷</li>
							<li>山地车</li>
						</ol>
					</li>
				</ul>
			</div>
		</nav>
	</body>
</html>

 

 

8.2.2.4 列表样式的设计 

为子菜单列表项设计样式,确保与主菜单一致或有所区分

<!DOCTYPE html>
<html>
	<head>
		<meta charset="utf-8" />
		<title>出式子导航栏的制作</title>
		<style type="text/css">
			/* 8.2.2.1 导航栏的创建 */
			/* 8.2.2.2 DIV样式的设计 */
			div{
				background-color: #33cc00;
				width: 150px;
				padding: 10px;
			}
			h3{
				color: #eeeeee;
				text-align: center;
				
			}
			/* 8.2.2.4 列表样式的设计 */
			ul, ol{
				list-style-type: none;
				margin: 0;
				padding: 0;
			}
		</style>
	</head>
	<body>
		<nav>
			<div id="nav">
				<h3 class="tit">所有商品分类</h3>
				<ul>
					<li>家居用品<img src="img/more.JPG" align="right" />
						<ol>
							<li>收纳箱</li>
							<li>雨伞雨具</li>
							<li>家务清洁</li>
							<li>茶具</li>
							<li>环保袋</li>
						</ol>
					</li>
					<li>手机数码<img src="img/more.JPG" align="right" />
						<ol>
							<li>电脑主机</li>
							<li>鼠标键盘</li>
							<li>无人机</li>
							<li>数码相机</li>
						</ol>
					</li>
					<li>家用电器<img src="img/more.JPG" align="right" />
						<ol>
							<li>吸尘器</li>
							<li>电饭煲</li>
							<li>冰箱</li>
						</ol>
					</li>
					<li>厨卫工具<img src="img/more.JPG" align="right" />
						<ol>
							<li>消毒柜</li>
							<li>抽油烟机</li>
							<li>碗柜</li>
							<li>花洒笼头</li>
							<li>洗手台</li>
						</ol>
					</li>
					<li>汽车用品<img src="img/more.JPG" align="right" />
						<ol>
							<li>打蜡服务</li>
							<li>超级试驾</li>
							<li>导航仪</li>
							<li>机油</li>
						</ol>
					</li>
					<li>运动器材<img src="img/more.JPG" align="right" />
						<ol>
							<li>跑鞋</li>
							<li>帐篷</li>
							<li>山地车</li>
						</ol>
					</li>
				</ul>
			</div>
		</nav>
	</body>
</html>

 

8.2.2.5 超链接样式的设计

 利用CSS 为超链接重新设置样式,对超链接的a:link 和a:visited进行设置,表示超链接未被访问和已访问状态

<!DOCTYPE html>
<html>
	<head>
		<meta charset="utf-8" />
		<title>出式子导航栏的制作</title>
		<style type="text/css">
			/* 8.2.2.1 导航栏的创建 */
			/* 8.2.2.2 DIV样式的设计 */
			div{
				background-color: #33cc00;
				width: 150px;
				padding: 10px;
			}
			h3{
				color: #eeeeee;
				text-align: center;
				
			}
			/* 8.2.2.4 列表样式的设计 */
			ul, ol{
				list-style-type: none;
				margin: 0;
				padding: 0;
			}
			/* 8.2.2.3 二级菜单的隐藏和显示设计 */
			ul li{
				position: relative;
			}
			ul li ol{
				display: none;
				position: absolute;
				left: 150px;
				top: -1px;
			}
			ul li:hover ol{
				display: block;
			}
			/* 8.2.2.5 超链接样式的设计 */
			a{
				display: block;
				width: 150px;
				line-height: 30px;
				text-decoration: none;
				text-align: center;
				background-color: #eeeeee;
				color: #33cc00;
			}
		</style>
	</head>
	<body>
		<nav>
			<div id="nav">
				<h3 class="tit">所有商品分类</h3>
				<ul>
					<li>家居用品<img src="img/more.JPG" align="right" />
						<ol>
							<li>收纳箱</li>
							<li>雨伞雨具</li>
							<li>家务清洁</li>
							<li>茶具</li>
							<li>环保袋</li>
						</ol>
					</li>
					<li>手机数码<img src="img/more.JPG" align="right" />
						<ol>
							<li>电脑主机</li>
							<li>鼠标键盘</li>
							<li>无人机</li>
							<li>数码相机</li>
						</ol>
					</li>
					<li>家用电器<img src="img/more.JPG" align="right" />
						<ol>
							<li>吸尘器</li>
							<li>电饭煲</li>
							<li>冰箱</li>
						</ol>
					</li>
					<li>厨卫工具<img src="img/more.JPG" align="right" />
						<ol>
							<li>消毒柜</li>
							<li>抽油烟机</li>
							<li>碗柜</li>
							<li>花洒笼头</li>
							<li>洗手台</li>
						</ol>
					</li>
					<li>汽车用品<img src="img/more.JPG" align="right" />
						<ol>
							<li>打蜡服务</li>
							<li>超级试驾</li>
							<li>导航仪</li>
							<li>机油</li>
						</ol>
					</li>
					<li>运动器材<img src="img/more.JPG" align="right" />
						<ol>
							<li>跑鞋</li>
							<li>帐篷</li>
							<li>山地车</li>
						</ol>
					</li>
				</ul>
			</div>
		</nav>
	</body>
</html>

 

8.3 底部固定导航栏

 底部导航,顾名思义是放在页脚部位,是网站设计中一种辅助导航

8.3.1 导航栏的创建

在<nav>的首尾标签之间,使用<div>标签创建菜单范围,结合无序列表<ul>配合列表选项<li>创建菜单选项

<!DOCTYPE html>
<html>
	<head>
		<meta charset="utf-8">
		<title>底部导航栏的制作</title>
		<style type="text/css">
			
		</style>
	</head>
	<body>
		<nav>
			<div class="fix-footer">
				<ul>
					<li><a href="#">首页</a></li>
					<li><a href="#">前端</a></li>
					<li><a href="#">后台</a></li>
					<li><a href="#">移动应用</a></li>
				</ul>
			</div>
		</nav>
	</body>
</html>

 

 

8.3.2 列表样式的设计

带有<ul>元素的默认实心点标记,可以利用list-style-type 属性去掉,同时设置margin 和 padding 属性

<!DOCTYPE html>
<html>
	<head>
		<meta charset="utf-8">
		<title>底部导航栏的制作</title>
		<style type="text/css">
			/* 8.3.1 导航栏的创建 */
			/* 8.3.2 列表样式的设计 */
			ul{
				list-style-type: none;
				margin: 0;
				padding: 0;
			}
			li{
				float: left;
			}
		</style>
	</head>
	<body>
		<nav>
			<div class="fix-footer">
				<ul>
					<li>首页</li>
					<li>前端</li>
					<li>后台</li>
					<li>移动应用</li>
				</ul>
			</div>
		</nav>
	</body>
</html>

 

 

8.3.3 菜单固定底部的设计

为了美化文字内容的外观,可以设置div的高度、宽度、背景、边框和文本对齐方式等。为了使导航菜单始终处于页面的最上层,需要设置z-index属性的优先值

<!DOCTYPE html>
<html>
	<head>
		<meta charset="utf-8">
		<title>底部导航栏的制作</title>
		<style type="text/css">
			/* 8.3.1 导航栏的创建 */
			/* 8.3.2 列表样式的设计 */
			ul{
				list-style-type: none;
				margin: 0;
				padding: 0;
			}
			li{
				float: left;
			}
			/* 8.3.4 超链接样式的设计 */
			a{
				display: block;
				width: 80px;
				padding: 10px;
				text-align: center;
				text-decoration: none;
			}
			/* 8.3.5 鼠标事件 */
			a:link, a:visited{
				background-color: #0000ff;
				color: #ffff00;
			}
			a:hover, a:active{
				background-color: #ffff00;
				color: #0000ff;
			}
			/* 8.3.3 菜单固定底部的设计 */
			.fix-footer{
				position: fixed;
				bottom: 0%;
			}
		</style>
	</head>
	<body>
		<br /><br /><br /><br /><br /><br /><br /><br /><br /><br /><br /><br /><br /><br />
		<nav>
			<div class="fix-footer">
				<ul>
					<li>首页</li>
					<li>前端</li>
					<li>后台</li>
					<li>移动应用</li>
				</ul>
			</div>
		</nav>
	</body>
</html>

 

8.3.4 超链接样式的设计

 利用CSS 为超链接重新设置样式,对超链接的a:link 和a:visited进行设置,表示超链接未被访问和已访问状态。然后将其display属性设置为block,使得超链接成为块级元素

<!DOCTYPE html>
<html>
	<head>
		<meta charset="utf-8">
		<title>底部导航栏的制作</title>
		<style type="text/css">
			/* 8.3.1 导航栏的创建 */
			/* 8.3.2 列表样式的设计 */
			ul{
				list-style-type: none;
				margin: 0;
				padding: 0;
			}
			li{
				float: left;
			}
			/* 8.3.4 超链接样式的设计 */
			a{
				display: block;
				width: 80px;
				padding: 10px;
				text-align: center;
				text-decoration: none;
			}
		</style>
	</head>
	<body>
		<nav>
			<div class="fix-footer">
				<ul>
					<li>首页</li>
					<li>前端</li>
					<li>后台</li>
					<li>移动应用</li>
				</ul>
			</div>
		</nav>
	</body>
</html>

 

8.4 综合案例——优名养生馆 

 8.4.1 封面页的设计与实现

<!DOCTYPE html>
<html>
	<head>
		<meta charset="utf-8">
		<title>优名养生馆</title>
		<style type="text/css">
			body{
				background-image: url(img/bg.JPG)
			}
			ul{
				margin: 0;
				padding: 0;
				list-style-type: none;
			}
			li{
				width: 25%;
				float: left;
				line-height: 50px;
			}
			img{
				margin-top: 70px;
				margin-right: 40px;
			}
			.footer{
				height: 50px;
				width: 100%;
				background-image: url(img/footer-bg.jpg);
				border-top: 3px solid gray;
				text-align:center;
				z-index: 9998;
				position: fixed;
				bottom: 0;
				left: 0;
			}
			.footer-top{
				height: 90px;
				width: 90px;
				text-align: center;
				line-height: 90px;
				z-index: 9999;
				position: fixed;
				bottom: 0;
				left: 45%;
			}
			.footer-top a{
				border-radius: 90px;
			}
			.footer-top a:link,a:visited{
				display: block;
				font-size: 20px;
				color: brown;
				text-decoration: none;
				font-weight: bold;
				border-top: 3px solid gray;
				background-image: url(img/footer-top-bg1.jpg);
			}
			.footer-top a:hover{
				background-image: url(img/footer-top-bg2.jpg);
				color: white;
			}
			.footer a:link,a:visited{
				display: block;
				font-size: 20px;
				color: brown;
				text-decoration: none;
				font-weight: bold;
			}
			.footer a:hover{
				background-color: darkgray;
				border-left: 2px solid white;
				border-right: 2px solid white ;
				font-size: 16px;
				color: red;
			}
		</style>
	</head>
	<body>
		<div>
			<marquee direction="right" scrollamount="20">
				<img src="img/marquee1.jpg"/>
				<img src="img/marquee2.jpg"/>
				<img src="img/marquee3.jpg"/>
			</marquee>
		</div>
		<nav>
			<div class="footer-top">
				进入官网
			</div>
			<div class="footer">
				<ul>
					<li>奇幻世界</li>
					<li>主题风采</li>
					<li>加盟相关</li>
					<li>友情推荐</li>
				</ul>
			</div>
		</nav>
	</body>
</html>

 

 

 

 

 

8.4.2 主页的设计与实现 

<!DOCTYPE html>
<html>
	<head>
		<meta charset="utf-8">
		<title>优名养生馆</title>
		<style>
			body{
				background-image: url(img/img/bg.jpg);
			}
			.all{
				margin: 0px auto;
				width: 900px;
			}
			.top{
				width: 900px;
				height: 225px;
				background-image: url(img/img/top-bg.jpg);
			}
			.cent{
				width: 320px;
				margin-left: auto;
				margin-right: auto;
				font-size: 58px;
				font-family: "楷体";
				color:lemonchiffon;
				font-style: italic;
			}
			.nav{
				width: 200px;
				float: left;
				margin-top: 30px;
				font-size: 20px;
				font-weight: bold;
				color: saddlebrown;
			}
			.main{
				width: 700px;
				height: 300px;
				float: left;
				margin-top: 10px;
			}
			.footer{
				font-size: 14px;
				font-weight: bold;
				color: brown;
				text-align: center;
				clear: both;
				background-image: url(img/img/footer-bg.jpg);
			}
			p{
				color: brown;
				font-size: 16px;
			}
			img{
				margin: 15px;
			}
			ul{
				list-style-type: none;
			}
			li{
				height: 22px;
			}
			a:link{
				font-size: 16px;
				text-decoration: none;
				color: brown;
			}
			a:hover{
				background-color: burlywood;
				color: white;
			}
		</style>
	</head>
	<body>
		<div class="all">
			<div class="top">
				<br>
				<div class="cent">优名养生馆</div>
			</div>
			<nav>
				<div class="nav">
					<table>
						<tr>养生之道</tr>
						<tr>
							<ul>
								<li>运动养生</li>
								<li>四季养生</li>
								<li>健康检测</li>
							</ul>
						</tr>
						<tr>中医养生</tr>
						<tr>
							<ul>
								<li>经络养生</li>
								<li>体质养生</li>
								<li>特色疗法</li>
							</ul>
						</tr>
					</table>
				</div>
			</nav>
			<div class="main">
				<img src="img/img/main.jpg" align="left"/>
				<p>&emsp;&emsp;古人云:善养生者,上养神智、中养形态、下养筋骨。</p > 
				<p>&emsp;&emsp;养生不是简单的体育锻炼、也不是吃一顿营养餐、打一套太极拳。养生是以 调阴阳、和气血、保精神为原则,
				运用调神、导引吐纳、四时调摄、食养、药养、节欲、服气辟谷等多种方法,以期达到保养、调养、颐养生命,实现人类健康、长寿的目的。</p > 
				<p>&emsp;&emsp;养生,是养护保养生命,以达长寿。养生是指有目的的通过各种手段护养人 体生命的行为,即根据人体生命过程的活动规律
				所进行的物质与精神的身心护养活动。也包括心理层面的养生,腔调内在精神的平衡和祥和。
				按照层次划分,生理层面的养生包括养颜、养体、养老;心理层面的养生包括养心、养性、养神。</p >
			</div>
			<hr />
			<div class="footer">版权所有&copy;优名养生馆</div>
		</div>
	</body>
</html>

 


网站公告

今日签到

点亮在社区的每一天
去签到