青少年编程与数学 01-006 设计网页的外观 18课题、导航栏2_1
易用的导航对于任何网站都很重要。通过使用 CSS,您可以将无聊的 HTML 菜单转换为美观的导航栏。
“探索是人类的本性。”
“To explore is to be human.”
—— 卡尔·萨根 (Carl Sagan) | 美国天文学家、科普作家 | 1934 ~ 1996
“航海者虽然依靠星辰,但必须自己掌舵。”
“Though the mariner may rely on the stars, he must steer by them.”
—— 亨利·戴维·梭罗 (Henry David Thoreau) | 美国作家、哲学家 | 1817 ~ 1862
“地图上的每一英寸都是一个新世界。”
“Every inch of the map is a new world.”
—— 理查德·弗朗西斯·伯顿 (Richard Francis Burton) | 英国探险家、地理学家 | 1821 ~ 1890
课题摘要
易用的导航对于任何网站都很重要。通过使用 CSS,您可以将无聊的 HTML 菜单转换为美观的导航栏。
课题要求
掌握导航栏的编写方法。
一、导航栏 = 链接列表
导航栏需要标准 HTML 作为基础。导航栏基本上就是链接列表,因此使用 <ul>
和 <li>
元素会很有意义:
<ul>
<li><a href="index.html">Home</a></li>
<li><a href="news.html">News</a></li>
<li><a href="contact.html">Contact</a></li>
<li><a href="about.html">About</a></li>
</ul>
二、垂直导航栏
如需构建垂直导航栏,可以在列表中设置 <a>
元素的样式:
li a {
display: block;
width: 60px;
}
display: block; - 将链接显示为块元素可以使整个链接区域都可以被单击(而不仅仅是文本),我们还可以指定宽度(如果需要,还可以指定内边距、外边距、高度等)。
width: 60px; - 默认情况下,块元素会占用全部可用宽度。我们需要指定 60 像素的宽度。
您还可以设置 <ul>
的宽度,并删除 <a>
的宽度,因为当显示为块元素时,它们将占据可用的全部宽度。这将导致与我们之前的例子相同的结果:
ul {
list-style-type: none;
margin: 0;
padding: 0;
width: 60px;
}
li a {
display: block;
}
三、水平导航栏
有两种创建水平导航栏的方法:使用行内或浮动列表项。
构建水平导航栏的一种方法是,将 <li>
元素指定为 inline:
li {
display: inline;
}
display: inline; -默认情况下,<li>
元素是块元素。在这里,我们删除每个列表项之前和之后的换行符,这样它们才能显示在一行。
浮动列表项:创建水平导航栏的另一种方法是浮动 <li>
元素,并为导航链接规定布局:
li {
float: left;
}
a {
display: block;
padding: 8px;
background-color: #dddddd;
}
float: left; - 使用 float 使块元素滑动为彼此相邻
display: block; - 将链接显示为块元素可以使整个链接区域都可单击(不仅是文本),而且允许我们指定填充(如果需要,还可以指定高度,宽度,边距等)
padding: 8px; - 使块元素更美观
background-color: #dddddd; - 为每个元素添加灰色背景色
提示:如需全宽的背景色,请将 background-color 添加到 <ul>
而不是每个 <a>
元素:
ul {
background-color: #dddddd;
}
水平导航栏实例:
创建具有深色背景色的基础水平导航栏,并在用户将鼠标移到链接上方时改变链接的背景色:
ul {
list-style-type: none;
margin: 0;
padding: 0;
overflow: hidden;
background-color: #333;
}
li {
float: left;
}
li a {
display: block;
color: white;
text-align: center;
padding: 14px 16px;
text-decoration: none;
}
/* 当鼠标悬停时把链接颜色更改为 #111(黑色) */
li a:hover {
background-color: #111;
}
活动/当前导航链接:向当前链接添加 “active” 类,这样用户就知道他/她在哪个页面上:
.active {
background-color: #4CAF50;
}
右对齐链接:通过将列表项向右浮动来右对齐链接(float:right;):
<ul>
<li><a href="#home">Home</a></li>
<li><a href="#news">News</a></li>
<li><a href="#contact">Contact</a></li>
<li style="float:right"><a class="active" href="#about">About</a></li>
</ul>
边框分隔栏:将 border-right 属性添加到 <li>
,以创建链接分隔符:
/* 为所有列表项添加灰色右边框,最后一项(last-child)除外 */
li {
border-right: 1px solid #bbb;
}
li:last-child {
border-right: none;
}
固定的导航栏:使导航栏保持在页面的顶部或底部,即使用户滚动页面也是如此:
固定在顶部:
ul {
position: fixed;
top: 0;
width: 100%;
}
固定在底部:
ul {
position: fixed;
bottom: 0;
width: 100%;
}
固定定位在移动设备上可能无法正常工作。
灰色水平导航栏:带有细灰色边框的灰色水平导航栏的实例
ul {
border: 1px solid #e7e7e7;
background-color: #f3f3f3;
}
li a {
color: #666;
}
粘性导航栏:为 <ul>
添加 position: sticky;,以创建粘性导航栏。粘性元素会根据滚动位置在相对和固定之间切换。它是相对定位的,直到在视口中遇到给定的偏移位置为止 - 然后将其“粘贴”在适当的位置(比如 position:fixed)。
ul {
position: -webkit-sticky; /* Safari */
position: sticky;
top: 0;
}