CSS 导航栏


导航栏

熟练使用导航栏,对于任何网站都非常重要。

使用CSS你可以转换成好看的导航栏而不是枯燥的HTML菜单。


导航栏=链接列表

作为标准的HTML基础一个导航栏是必须的。

在我们的例子中我们将建立一个标准的HTML列表导航栏。

导航条基本上是一个链接列表,所以使用 <ul> 和 <li> 元素非常有意义:

完整代码如下:

<!DOCTPYE html>
<html lang="zh">
<head>
	<link rel="icon" href="beyond.jpg" type="image/x-icon"/>
	<meta charset="UTF-8">
	<meta name="author" content="beyond">
	<meta http-equiv="refresh" content="520">
	<meta name="description" content="免费零基础教程">
	<meta name="viewport" content="width=device-width, 
	initial-scale=1.0, maximum-scale=1.0,minimum-scale=1.0,user-scalable=0" />
	<meta name="keywords" content="HTML,CSS,JAVASCRIPT">
	<title>beyondの心中の动漫神作</title>
	<link rel="stylesheet" type="text/css" href="beyondbasestylewhite3.css">

	<!--[if lt IE 9]>
		<script src="//apps.bdimg.com/libs/html5shiv/3.7/html5shiv.min.js"></script>
	<![endif]-->

	<style type="text/css">
		body{
			font-size: 100%;
			background-image: url("sakura4.png");
			background-repeat: no-repeat;
			background-position: center center;
			/*声明margin和padding是个好习惯*/
			margin: 0;
			padding: 0;
		}
	</style>
</head>

<body>
	
		<h1 style="color:white;text-shadow:2px 2px 4px #000;letter-spacing:5px;" class="sgcontentcolor sgcenter">
			未 闻 花 名
		</h1>
		<ul>
			<li> <a href="#">主页</a></li>
			<li> <a href="#">动漫</a></li>
			<li> <a href="#">民间偏方</a></li>
			<li> <a href="#">编程</a></li>
			<li> <a href="#">APP</a></li>
		</ul>
		<p class="sgcontentcolor sgcenter" style="clear:left;">
			<b>注意:</b>
			导航一般是用ul和li
		</p>
		<!-- <a style="color:red;"></a> -->
		<footer id="copyright">
			<p style="font-size:14px;text-align:center;font-style:italic;">
			Copyright © <a id="author">2018</a> Powered by <a id="author">beyond</a>
			</p>		
		</footer>


	
</body>
</html>

效果如下:



核心代码:

  • <ul> 
    <li><a href="default.asp">Home</a></li> 
    <li><a href="news.asp">News</a></li> 
    <li><a href="contact.asp">Contact</a></li> 
    <li><a href="about.asp">About</a></li> 
    </ul> 

现在,让我们从列表中删除边距和填充:

效果如下:



核心代码:

ul { 
  list-style-type:none; 
  margin:0; 
  padding:0; 
}

例子解析:

  • list-style-type:none - 移除列表前小标志。一个导航栏并不需要列表标记

  • 移除浏览器的默认设置将边距和填充设置为0

上面的例子中的代码是垂直和水平导航栏使用的标准代码。


垂直导航栏

上面的代码,我们只需要 元素的样式,建立一个垂直的导航栏:

核心代码:

a {  background-color:#eee;
  display:block; 
  width:70px; 
}

效果如下:


示例说明:

  • display:block - 将inline的a转换成block块元素的链接,让整体变为可点击链接区域(不只是文本),它允许我们指定宽度大小

  • width:70px - 块元素默认情况下是最大宽度。我们要指定一个70像素的宽度

提示:查看完全样式的垂直导航栏的示例.

完整代码如下:

<!DOCTPYE html>
<html lang="zh">
<head>
	<link rel="icon" href="beyond.jpg" type="image/x-icon"/>
	<meta charset="UTF-8">
	<meta name="author" content="beyond">
	<meta http-equiv="refresh" content="520">
	<meta name="description" content="免费零基础教程">
	<meta name="viewport" content="width=device-width, 
	initial-scale=1.0, maximum-scale=1.0,minimum-scale=1.0,user-scalable=0" />
	<meta name="keywords" content="HTML,CSS,JAVASCRIPT">
	<title>beyondの心中の动漫神作</title>
	<link rel="stylesheet" type="text/css" href="beyondbasestylewhite3.css">

	<!--[if lt IE 9]>
		<script src="//apps.bdimg.com/libs/html5shiv/3.7/html5shiv.min.js"></script>
	<![endif]-->

	<style type="text/css">
		body{
			font-size: 100%;
			background-image: url("sakura4.png");
			background-repeat: no-repeat;
			background-position: center center;
			/*声明margin和padding是个好习惯*/
			margin: 0;
			padding: 0;
		}
		ul {
			list-style-type: none;
			margin: 0;
			padding: 0;
		}
		li a:link,li a:visited {
			/*将inline的a转变成block元素*/
			display: block;
			font-weight: bold;
			color: #fff;
			background-color: #98bf21;
			width: 120px;
			text-align: center;
			padding: 4px;
			text-decoration: none;
			text-transform: uppercase;			
		}
		li a:hover,li a:active {
			background-color: #7A991A;
		}

	</style>
</head>

<body>
	
		<h1 style="color:white;text-shadow:2px 2px 4px #000;letter-spacing:5px;" class="sgcontentcolor sgcenter">
			未 闻 花 名
		</h1>
		<ul>
			<li> <a href="#">主页</a></li>
			<li> <a href="#">动漫</a></li>
			<li> <a href="#">民间偏方</a></li>
			<li> <a href="#">编程</a></li>
			<li> <a href="#">APP</a></li>
		</ul>
		<p class="sgcontentcolor sgcenter" style="clear:left;">
			<b>注意:</b>
			导航一般是用ul和li
		</p>
		<!-- <a style="color:red;"></a> -->
		<footer id="copyright">
			<p style="font-size:14px;text-align:center;font-style:italic;">
			Copyright © <a id="author">2018</a> Powered by <a id="author">beyond</a>
			</p>		
		</footer>


	
</body>
</html>

效果如下:


注意: 请务必指定 元素在垂直导航栏的的宽度。如果省略宽度,IE6可能产生意想不到的效果。


水平导航栏

有两种方法创建水平的横向导航栏。使用内联inline浮动float的列表项li。

这两种方法都很好,但如果你想链接到具有相同的大小,你必须使用浮动float的方法。


内嵌列表项 inline

建立一个水平横向导航栏的方法之一是inline

li元素, 上述代码是标准的内嵌 inline:

代码如下:

<!DOCTPYE html>
<html lang="zh">
<head>
	<link rel="icon" href="beyond.jpg" type="image/x-icon"/>
	<meta charset="UTF-8">
	<meta name="author" content="beyond">
	<meta http-equiv="refresh" content="520">
	<meta name="description" content="免费零基础教程">
	<meta name="viewport" content="width=device-width, 
	initial-scale=1.0, maximum-scale=1.0,minimum-scale=1.0,user-scalable=0" />
	<meta name="keywords" content="HTML,CSS,JAVASCRIPT">
	<title>beyondの心中の动漫神作</title>
	<link rel="stylesheet" type="text/css" href="beyondbasestylewhite3.css">

	<!--[if lt IE 9]>
		<script src="//apps.bdimg.com/libs/html5shiv/3.7/html5shiv.min.js"></script>
	<![endif]-->

	<style type="text/css">
		body{
			font-size: 100%;
			background-image: url("sakura4.png");
			background-repeat: no-repeat;
			background-position: center center;
			/*声明margin和padding是个好习惯*/
			margin: 0;
			padding: 0;
		}
		ul {
			list-style-type: none;
			margin: 0;
			padding: 0;
		}
		li {
			/*将block变成inline*/
			display: inline;
		}

	</style>
</head>

<body>
	
		<h1 style="color:white;text-shadow:2px 2px 4px #000;letter-spacing:5px;" class="sgcontentcolor sgcenter">
			未 闻 花 名
		</h1>
		<ul>
			<li> <a href="#">主页</a></li>
			<li> <a href="#">动漫</a></li>
			<li> <a href="#">民间偏方</a></li>
			<li> <a href="#">编程</a></li>
			<li> <a href="#">APP</a></li>
		</ul>
		<p class="sgcontentcolor sgcenter" style="clear:left;">
			<b>注意:</b>
			导航一般是用ul和li
		</p>
		<!-- <a style="color:red;"></a> -->
		<footer id="copyright">
			<p style="font-size:14px;text-align:center;font-style:italic;">
			Copyright © <a id="author">2018</a> Powered by <a id="author">beyond</a>
			</p>		
		</footer>


	
</body>
</html>

效果如下:


核心代码:

li { 
  display:inline; 
}

实例解析:

  • display:inline - 默认情况下,<li>元素是block块元素。在这里,我们将其转换成inline元素之后,删除了换行符,每个列表项便显示成了一行。

提示: 查看完全样式的水平导航栏的示例.

代码如下:

<!DOCTPYE html>
<html lang="zh">
<head>
	<link rel="icon" href="beyond.jpg" type="image/x-icon"/>
	<meta charset="UTF-8">
	<meta name="author" content="beyond">
	<meta http-equiv="refresh" content="520">
	<meta name="description" content="免费零基础教程">
	<meta name="viewport" content="width=device-width, 
	initial-scale=1.0, maximum-scale=1.0,minimum-scale=1.0,user-scalable=0" />
	<meta name="keywords" content="HTML,CSS,JAVASCRIPT">
	<title>beyondの心中の动漫神作</title>
	<link rel="stylesheet" type="text/css" href="beyondbasestylewhite3.css">

	<!--[if lt IE 9]>
		<script src="//apps.bdimg.com/libs/html5shiv/3.7/html5shiv.min.js"></script>
	<![endif]-->

	<style type="text/css">
		body{
			font-size: 100%;
			background-image: url("sakura4.png");
			background-repeat: no-repeat;
			background-position: center center;
			/*声明margin和padding是个好习惯*/
			margin: 0;
			padding: 0;
		}
		ul {
			list-style-type: none;
			margin: 0;
			padding: 0;
		}
		li {
			/*将block变成inline*/
			display: inline;
		}
		li a:link,li a:visited {
			font-weight: bold;
			color: #fff;
			background-color: #98bf21;
			text-align: center;
			padding: 6px;
			text-decoration: none;
			text-transform: uppercase;
		}
		li a:hover,li a:active {
			background-color: #7A991A;
		}

	</style>
</head>

<body>
	
		<h1 style="color:white;text-shadow:2px 2px 4px #000;letter-spacing:5px;" class="sgcontentcolor sgcenter">
			未 闻 花 名
		</h1>
		<ul>
			<li> <a href="#">主页</a></li>
			<li> <a href="#">动漫</a></li>
			<li> <a href="#">民间偏方</a></li>
			<li> <a href="#">编程</a></li>
			<li> <a href="#">APP</a></li>
		</ul>
		<p class="sgcontentcolor sgcenter" style="clear:left;">
			<b>注意:</b>
			导航一般是用ul和li<br/>
			水平导航可以用inline,但不同宽
		</p>
		<!-- <a style="color:red;"></a> -->
		<footer id="copyright">
			<p style="font-size:14px;text-align:center;font-style:italic;">
			Copyright © <a id="author">2018</a> Powered by <a id="author">beyond</a>
			</p>		
		</footer>


	
</body>
</html>

效果如下:



浮动列表项 float

在上面的inline例子中链接a有不同的宽度。

若是想要所有的水平导航链接都有宽度的相等,那么请使用float浮动,并指定一个宽度:

完整代码如下:

<!DOCTPYE html>
<html lang="zh">
<head>
	<link rel="icon" href="beyond.jpg" type="image/x-icon"/>
	<meta charset="UTF-8">
	<meta name="author" content="beyond">
	<meta http-equiv="refresh" content="520">
	<meta name="description" content="免费零基础教程">
	<meta name="viewport" content="width=device-width, 
	initial-scale=1.0, maximum-scale=1.0,minimum-scale=1.0,user-scalable=0" />
	<meta name="keywords" content="HTML,CSS,JAVASCRIPT">
	<title>beyondの心中の动漫神作</title>
	<link rel="stylesheet" type="text/css" href="beyondbasestylewhite3.css">

	<!--[if lt IE 9]>
		<script src="//apps.bdimg.com/libs/html5shiv/3.7/html5shiv.min.js"></script>
	<![endif]-->

	<style type="text/css">
		body{
			font-size: 100%;
			background-image: url("sakura4.png");
			background-repeat: no-repeat;
			background-position: center center;
			/*声明margin和padding是个好习惯*/
			margin: 0;
			padding: 0;
		}
		ul {
			list-style-type: none;
			margin: 0;
			padding: 0;
		}
		li {
			/*将其浮动,并指定等宽*/
			float: left;
		}

		li a:link,li a:visited {
			/*让里面的a标签变成block,并指定宽度*/
			display: block;
			width: 70px;

			font-weight: bold;
			color: #fff;
			background-color: #98bf21;
			text-align: center;
			padding: 6px;
			text-decoration: none;
			text-transform: uppercase;
		}
		li a:hover,li a:active {
			background-color: #7A991A;
		}

	</style>
</head>

<body>
	
		<h1 style="color:white;text-shadow:2px 2px 4px #000;letter-spacing:5px;" class="sgcontentcolor sgcenter">
			未 闻 花 名
		</h1>
		<ul>
			<li> <a href="#">主页</a></li>
			<li> <a href="#">动漫</a></li>
			<li> <a href="#">民间偏方</a></li>
			<li> <a href="#">编程</a></li>
			<li> <a href="#">APP</a></li>
		</ul>
		<p class="sgcontentcolor sgcenter" style="clear:left;">
			<b>注意:</b>
			导航一般是用ul和li<br/>
			水平导航可以将li变成float<br/>
			然后将里面的a变成block,设置等宽
		</p>
		<!-- <a style="color:red;"></a> -->
		<footer id="copyright">
			<p style="font-size:14px;text-align:center;font-style:italic;">
			Copyright © <a id="author">2018</a> Powered by <a id="author">beyond</a>
			</p>		
		</footer>


	
</body>
</html>

效果如下:


核心代码:

li { 
  float:left; 

a { 
  display:block; 
  width:70px; 
}

实例解析:

  • float:left - 使用float浮动块元素的幻灯片彼此相邻

  • display:block - 显示block块元素的a链接,让整体变为可点击链接区域(不只是文本),它允许我们指定宽度

  • width:70px - 块元素默认情况下是最大宽度。我们要指定一个70像素的宽度

  • display:inline; -默认情况下,

  • 元素是块元素。在这里,我们删除换行符之前和之后每个列表项,以显示一行 。

Tip:查看完全样式的横向导航栏的示例..