CSS 水平导航栏
水平导航栏
有两种创建水平导航条的方法:使用行内或浮动列表项。
行内列表项
构建水平导航条的一种方法是,除了上一章中的“标准”代码外,还要将 <li> 元素指定为 inline:
<!DOCTYPE html><html><head><style>ul {list-style-type: none;margin: 0;padding: 0;}li {display: inline;}</style></head><body><ul><li><a href="#home">首页</a></li><li><a href="#news">新闻</a></li><li><a href="#contact">联系方式</a></li><li><a href="#about">关于我们</a></li></ul></body></html>
例子解释:
display: inline; -默认情况下,<li> 元素是块元素。在这里,我们删除每个列表项之前和之后的换行符,这样它们才能显示在一行。
浮动列表项
创建水平导航条的另一种方法是浮动 <li> 元素,并为导航链接规定布局:
<!DOCTYPE html><html><head><style>ul {list-style-type: none;margin: 0;padding: 0;overflow: hidden;}li {float: left;}li a {display: block;padding: 8px;background-color: #dddddd;}</style></head><body><ul><li><a href="#home">首页</a></li><li><a href="#news">新闻</a></li><li><a href="#contact">联系方式</a></li><li><a href="#about">关于我们</a></li></ul><p><b>注释:</b>如果未指定 !DOCTYPE,则浮动项目可能会产生意外结果。</p><p>背景色被添加到链接以显示链接区域。整个链接区域都是可单击的,而不仅仅是文本。</p><p><b>注释:</b>overflow:hidden 被添加到 ul 元素,以防止 li 元素超出列表。</p></body></html>
例子解释:
float: left;- 使用 float 使块元素滑动为彼此相邻display: block;- 将链接显示为块元素可以使整个链接区域都可单击(不仅是文本),而且允许我们指定填充(如果需要,还可以指定高度,宽度,边距等)padding: 8px;- 使块元素更美观background-color: #dddddd;- 为每个元素添加灰色背景色
提示:如需全宽的背景色,请将 background-color 添加到 <ul> 而不是每个 <a> 元素:
<!DOCTYPE html><html><head><style>ul {list-style-type: none;margin: 0;padding: 0;overflow: hidden;background-color: #dddddd;}li {float: left;}li a {display: block;padding: 8px;}</style></head><body><ul><li><a href="#home">首页</a></li><li><a href="#news">新闻</a></li><li><a href="#contact">联系方式</a></li><li><a href="#about">关于我们</a></li></ul><p>将背景色添加到列表中(而不是每个链接),以创建全宽的背景色。</p><p><b>注释:</b>overflow:hidden 被添加到 ul 元素,以防止 li 元素超出列表。</p></body></html>
水平导航条实例
创建具有深色背景色的基础水平导航条,并在用户将鼠标移到链接上方时改变链接的背景色:
<!DOCTYPE html><html><head><style>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;}li a:hover {background-color: #111;}</style></head><body><ul><li><a class="active" href="#home">首页</a></li><li><a href="#news">新闻</a></li><li><a href="#contact">联系方式</a></li><li><a href="#about">关于我们</a></li></ul></body></html>
活动/当前导航链接
向当前链接添加 "active" 类,这样用户就知道他/她在哪个页面上:
代码如下:
<!DOCTYPE html><html><head><style>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;}li a:hover:not(.active) {background-color: #111;}.active {background-color: #04AA6D;}</style></head><body><ul><li><a class="active" href="#home">首页</a></li><li><a href="#news">新闻</a></li><li><a href="#contact">联系方式</a></li><li><a href="#about">关于我们</a></li></ul></body></html>
右对齐链接
通过将列表项向右浮动来右对齐链接(float:right;):
代码如下:
<!DOCTYPE html><html><head><style>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;}li a:hover:not(.active) {background-color: #111;}.active {background-color: #04AA6D;}</style></head><body><ul><li><a href="#home">首页</a></li><li><a href="#news">新闻</a></li><li><a href="#contact">联系方式</a></li><li style="float:right"><a class="active" href="#about">关于我们</a></li></ul></body></html>
边框分隔栏
将 border-right 属性添加到 <li>,以创建链接分隔符:
<!DOCTYPE html><html><head><style>ul {list-style-type: none;margin: 0;padding: 0;overflow: hidden;background-color: #333;}li {float: left;border-right:1px solid #bbb;}li:last-child {border-right: none;}li a {display: block;color: white;text-align: center;padding: 14px 16px;text-decoration: none;}li a:hover:not(.active) {background-color: #111;}.active {background-color: #04AA6D;}</style></head><body><ul><li><a class="active" href="javascript:void(0)">首页</a></li><li><a href="javascript:void(0)">新闻</a></li><li><a href="javascript:void(0)">联系方式</a></li><li style="float:right"><a href="javascript:void(0)">关于我们</a></li></ul></body></html>
固定的导航条
使导航条保持在页面的顶部或底部,即使用户滚动页面也是如此:
固定在顶部
<!DOCTYPE html><html><head><style>html, body {font-family: Verdana,sans-serif;font-size: 15px;line-height: 1.5}body {margin: 0;}ul {list-style-type: none;margin: 0;padding: 0;overflow: hidden;background-color: #333;position: fixed;top: 0;width: 100%;}li {float: left;}li a {display: block;color: white;text-align: center;padding: 14px 16px;text-decoration: none;}li a:hover:not(.active) {background-color: #111;}.active {background-color: #04AA6D;}</style></head><body><ul><li><a class="active" href="#home">首页</a></li><li><a href="#news">新闻</a></li><li><a href="#contact">联系方式</a></li></ul><div style="padding:20px;margin-top:30px;background-color:#1abc9c;height:1000px;"><h1>顶部固定导航条</h1><h2>滚动时,导航条将停留在页面顶部</h2><p>这是一些文本,这是一些文本</p><p>这是一些文本,这是一些文本</p><p>这是一些文本,这是一些文本</p><p>这是一些文本,这是一些文本</p><p>这是一些文本,这是一些文本</p><p>这是一些文本,这是一些文本</p><p>这是一些文本,这是一些文本</p><p>这是一些文本,这是一些文本</p><p>这是一些文本,这是一些文本</p><p>这是一些文本,这是一些文本</p><p>这是一些文本,这是一些文本</p><p>这是一些文本,这是一些文本</p><p>这是一些文本,这是一些文本</p><p>这是一些文本,这是一些文本</p></div></body></html>
固定在底部
<!DOCTYPE html><html><head><style>html, body {font-family: Verdana,sans-serif;font-size: 15px;line-height: 1.5}body {margin: 0;}ul {list-style-type: none;margin: 0;padding: 0;overflow: hidden;background-color: #333;position: fixed;bottom: 0;width: 100%;}li {float: left;}li a {display: block;color: white;text-align: center;padding: 14px 16px;text-decoration: none;}li a:hover:not(.active) {background-color: #111;}.active {background-color: #04AA6D;}</style></head><body><ul><li><a class="active" href="#home">首页</a></li><li><a href="#news">新闻</a></li><li><a href="#contact">联系方式</a></li></ul><div style="padding:20px;;background-color:#1abc9c;height:1000px;"><h1>底部固定导航条</h1><h2>滚动时,导航条将停留在页面底部</h2><p>这是一些文本,这是一些文本</p><p>这是一些文本,这是一些文本</p><p>这是一些文本,这是一些文本</p><p>这是一些文本,这是一些文本</p><p>这是一些文本,这是一些文本</p><p>这是一些文本,这是一些文本</p><p>这是一些文本,这是一些文本</p><p>这是一些文本,这是一些文本</p><p>这是一些文本,这是一些文本</p><p>这是一些文本,这是一些文本</p><p>这是一些文本,这是一些文本</p><p>这是一些文本,这是一些文本</p><p>这是一些文本,这是一些文本</p></div></body></html>
注意:固定定位在移动设备上可能无法正常工作。
灰色水平导航条
带有细灰色边框的灰色水平导航条的实例
代码如下:
<!DOCTYPE html><html><head><style>ul {list-style-type: none;margin: 0;padding: 0;overflow: hidden;border: 1px solid #e7e7e7;background-color: #f3f3f3;}li {float: left;}li a {display: block;color: #666;text-align: center;padding: 14px 16px;text-decoration: none;}li a:hover:not(.active) {background-color: #ddd;}li a.active {color: white;background-color: #4CAF50;}</style></head><body><ul><li><a class="active" href="javascript:void(0)">首页</a></li><li><a href="javascript:void(0)">新闻</a></li><li><a href="javascript:void(0)">联系方式</a></li><li><a href="javascript:void(0)">关于我们</a></li></ul></body></html>
粘性导航条
为 <ul> 添加 position: sticky;,以创建粘性导航条。粘性元素会根据滚动位置在相对和固定之间切换。它是相对定位的,直到在视口中遇到给定的偏移位置为止 - 然后将其“粘贴”在适当的位置(比如 position:fixed )。
实例
<!DOCTYPE html><html><head><style>body {font-size: 28px;}ul {list-style-type: none;margin: 0;padding: 0;overflow: hidden;background-color: #333;position: -webkit-sticky; /* Safari */position: sticky;top: 0;}li {float: left;}li a {display: block;color: white;text-align: center;padding: 14px 16px;text-decoration: none;}li a:hover {background-color: #111;}.active {background-color: #4CAF50;}</style></head><body><div class="header"><h3>向下滚动</h3><p>请向下滚动以查看粘性效果。</p></div><ul><li><a class="active" href="#home">Home</a></li><li><a href="#news">News</a></li><li><a href="#contact">Contact</a></li></ul><h3>粘性导航条实例</h3><p>当你滚动页面将导航条滚到顶部时,导航条将粘着顶部。</p><p>这是一些文本确保页面能够滚动.这是一些文本确保页面能够滚动.这是一些文本确保页面能够滚动.这是一些文本确保页面能够滚动.这是一些文本确保页面能够滚动.这是一些文本确保页面能够滚动.这是一些文本确保页面能够滚动.这是一些文本确保页面能够滚动.这是一些文本确保页面能够滚动.这是一些文本确保页面能够滚动.</p><p>这是一些文本确保页面能够滚动.这是一些文本确保页面能够滚动.这是一些文本确保页面能够滚动.这是一些文本确保页面能够滚动.这是一些文本确保页面能够滚动.这是一些文本确保页面能够滚动.这是一些文本确保页面能够滚动.这是一些文本确保页面能够滚动.这是一些文本确保页面能够滚动.这是一些文本确保页面能够滚动.</p><p>这是一些文本确保页面能够滚动.这是一些文本确保页面能够滚动.这是一些文本确保页面能够滚动.这是一些文本确保页面能够滚动.这是一些文本确保页面能够滚动.这是一些文本确保页面能够滚动.这是一些文本确保页面能够滚动.这是一些文本确保页面能够滚动.这是一些文本确保页面能够滚动.这是一些文本确保页面能够滚动.</p><p>这是一些文本确保页面能够滚动.这是一些文本确保页面能够滚动.这是一些文本确保页面能够滚动.这是一些文本确保页面能够滚动.这是一些文本确保页面能够滚动.这是一些文本确保页面能够滚动.这是一些文本确保页面能够滚动.这是一些文本确保页面能够滚动.这是一些文本确保页面能够滚动.这是一些文本确保页面能够滚动.</p><p>这是一些文本确保页面能够滚动.这是一些文本确保页面能够滚动.这是一些文本确保页面能够滚动.这是一些文本确保页面能够滚动.这是一些文本确保页面能够滚动.这是一些文本确保页面能够滚动.这是一些文本确保页面能够滚动.这是一些文本确保页面能够滚动.这是一些文本确保页面能够滚动.这是一些文本确保页面能够滚动.</p><p>这是一些文本确保页面能够滚动.这是一些文本确保页面能够滚动.这是一些文本确保页面能够滚动.这是一些文本确保页面能够滚动.这是一些文本确保页面能够滚动.这是一些文本确保页面能够滚动.这是一些文本确保页面能够滚动.这是一些文本确保页面能够滚动.这是一些文本确保页面能够滚动.这是一些文本确保页面能够滚动.</p></body></html>
注意:Internet Explorer、Edge 15 和更早版本不支持粘性定位。 Safari 需要 -webkit- 前缀(请参见上面的例子)。您还必须指定 top、right、bottom 或 left 至少之一,以使粘性定位起作用。