CSS 水平导航栏

水平导航栏

有两种创建水平导航栏的方法:使用行内浮动列表项。

行内列表项

构建水平导航栏的一种方法是,除了上一章中的“标准”代码外,还要将 <li> 元素指定为 inline:

实例

  1. li {
  2. display: inline;
  3. }

css_navbar_horizontal.htm

例子解释:

display: inline; -默认情况下,<li> 元素是块元素。在这里,我们删除每个列表项之前和之后的换行符,这样它们才能显示在一行。

浮动列表项

创建水平导航栏的另一种方法是浮动 <li> 元素,并为导航链接规定布局:

实例

  1. li {
  2. float: left;
  3. }
  4. a {
  5. display: block;
  6. padding: 8px;
  7. background-color: #dddddd;
  8. }

css_navbar_horizontal_float_1.htm

例子解释:

  • float: left; - 使用 float 使块元素滑动为彼此相邻
  • display: block; - 将链接显示为块元素可以使整个链接区域都可单击(不仅是文本),而且允许我们指定填充(如果需要,还可以指定高度,宽度,边距等)
  • padding: 8px; - 使块元素更美观
  • background-color: #dddddd; - 为每个元素添加灰色背景色

提示:如需全宽的背景色,请将 background-color 添加到 <ul> 而不是每个 <a> 元素:

实例

  1. ul {
  2. background-color: #dddddd;
  3. }

css_navbar_horizontal_float_2.htm

水平导航栏实例

创建具有深色背景色的基础水平导航栏,并在用户将鼠标移到链接上方时改变链接的背景色:

实例

  1. ul {
  2. list-style-type: none;
  3. margin: 0;
  4. padding: 0;
  5. overflow: hidden;
  6. background-color: #333;
  7. }
  8. li {
  9. float: left;
  10. }
  11. li a {
  12. display: block;
  13. color: white;
  14. text-align: center;
  15. padding: 14px 16px;
  16. text-decoration: none;
  17. }
  18. /* 当鼠标悬停时把链接颜色更改为 #111(黑色) */
  19. li a:hover {
  20. background-color: #111;
  21. }

css_navbar_horizontal_black.htm

活动/当前导航链接

向当前链接添加 “active” 类,这样用户就知道他/她在哪个页面上:

实例

  1. .active {
  2. background-color: #4CAF50;
  3. }

css_navbar_horizontal_black_active.htm

右对齐链接

通过将列表项向右浮动来右对齐链接(float:right;):

实例

  1. <ul>
  2. <li><a href="#home">Home</a></li>
  3. <li><a href="#news">News</a></li>
  4. <li><a href="#contact">Contact</a></li>
  5. <li style="float:right"><a class="active" href="#about">About</a></li>
  6. </ul>

css_navbar_horizontal_black_right.htm

边框分隔栏

border-right 属性添加到 <li>,以创建链接分隔符:

实例

  1. /* 为所有列表项添加灰色右边框,最后一项(last-child)除外 */
  2. li {
  3. border-right: 1px solid #bbb;
  4. }
  5. li:last-child {
  6. border-right: none;
  7. }

css_navbar_horizontal_dividers.htm

固定的导航栏

使导航栏保持在页面的顶部或底部,即使用户滚动页面也是如此:

固定在顶部

  1. ul {
  2. position: fixed;
  3. top: 0;
  4. width: 100%;
  5. }

css_navbar_horizontal_black_fixed_1.htm

固定在底部

  1. ul {
  2. position: fixed;
  3. bottom: 0;
  4. width: 100%;
  5. }

css_navbar_horizontal_black_fixed_2.htm

注意:固定定位在移动设备上可能无法正常工作。

灰色水平导航栏

带有细灰色边框的灰色水平导航栏的实例

实例

  1. ul {
  2. border: 1px solid #e7e7e7;
  3. background-color: #f3f3f3;
  4. }
  5. li a {
  6. color: #666;
  7. }

css_navbar_horizontal_gray.htm

粘性导航栏

<ul> 添加 position: sticky;,以创建粘性导航栏。

粘性元素会根据滚动位置在相对和固定之间切换。它是相对定位的,直到在视口中遇到给定的偏移位置为止 - 然后将其“粘贴”在适当的位置(比如 position:fixed)。

实例

  1. ul {
  2. position: -webkit-sticky; /* Safari */
  3. position: sticky;
  4. top: 0;
  5. }

css_navbar_sticky.htm

注意:Internet Explorer、Edge 15 和更早版本不支持粘性定位。 Safari 需要 -webkit- 前缀(请参见上面的例子)。您还必须指定 toprightbottomleft 至少之一,以使粘性定位起作用。

更多实例

响应式的上导航栏

如何使用 CSS 媒体查询来创建响应式顶部导航。

  1. <head>
  2. <meta name="viewport" content="width=device-width, initial-scale=1.0">
  3. <style>
  4. body {margin: 0;}
  5. ul.topnav {
  6. list-style-type: none;
  7. margin: 0;
  8. padding: 0;
  9. overflow: hidden;
  10. background-color: #333;
  11. }
  12. ul.topnav li {float: left;}
  13. ul.topnav li a {
  14. display: block;
  15. color: white;
  16. text-align: center;
  17. padding: 14px 16px;
  18. text-decoration: none;
  19. }
  20. ul.topnav li a:hover:not(.active) {background-color: #111;}
  21. ul.topnav li a.active {background-color: #4CAF50;}
  22. ul.topnav li.right {float: right;}
  23. @media screen and (max-width: 600px) {
  24. ul.topnav li.right,
  25. ul.topnav li {float: none;}
  26. }
  27. </style>
  28. </head>
  29. <body>
  30. <ul class="topnav">
  31. <li><a class="active" href="#home">Home</a></li>
  32. <li><a href="#news">News</a></li>
  33. <li><a href="#contact">Contact</a></li>
  34. <li class="right"><a href="#about">About</a></li>
  35. </ul>
  36. <div style="padding:0 16px;">
  37. <h1>响应式顶部导航栏实例</h1>
  38. <p>此示例使用媒体查询在屏幕尺寸小于或等于 600 像素时垂直堆叠 topnav。</p>
  39. <p>您稍后将在我们的 CSS 教程中学到有关媒体查询和响应式 Web 设计的更多知识。</p>
  40. <p><b>请调整浏览器窗口的大小以查看效果。</b></p>
  41. </div>
  42. </body>

响应式的侧导航栏

如何使用 CSS 媒体查询来创建响应式侧导航。

  1. <head>
  2. <meta name="viewport" content="width=device-width, initial-scale=1.0">
  3. <style>
  4. body {margin: 0;}
  5. ul.sidenav {
  6. list-style-type: none;
  7. margin: 0;
  8. padding: 0;
  9. width: 25%;
  10. background-color: #f1f1f1;
  11. position: fixed;
  12. height: 100%;
  13. overflow: auto;
  14. }
  15. ul.sidenav li a {
  16. display: block;
  17. color: #000;
  18. padding: 8px 16px;
  19. text-decoration: none;
  20. }
  21. ul.sidenav li a.active {
  22. background-color: #4CAF50;
  23. color: white;
  24. }
  25. ul.sidenav li a:hover:not(.active) {
  26. background-color: #555;
  27. color: white;
  28. }
  29. div.content {
  30. margin-left: 25%;
  31. padding: 1px 16px;
  32. height: 1000px;
  33. }
  34. @media screen and (max-width: 900px) {
  35. ul.sidenav {
  36. width: 100%;
  37. height: auto;
  38. position: relative;
  39. }
  40. ul.sidenav li a {
  41. float: left;
  42. padding: 15px;
  43. }
  44. div.content {margin-left: 0;}
  45. }
  46. @media screen and (max-width: 400px) {
  47. ul.sidenav li a {
  48. text-align: center;
  49. float: none;
  50. }
  51. }
  52. </style>
  53. </head>
  54. <body>
  55. <ul class="sidenav">
  56. <li><a class="active" href="#home">Home</a></li>
  57. <li><a href="#news">News</a></li>
  58. <li><a href="#contact">Contact</a></li>
  59. <li><a href="#about">About</a></li>
  60. </ul>
  61. <div class="content">
  62. <h1>响应式侧导航栏实例</h1>
  63. <p>当屏幕尺寸为 900 像素或更小时,此例使用媒体查询将 sidenav 转换为顶部导航栏。</p>
  64. <p>我们还为屏幕小于等于 400 像素的屏幕添加了媒体查询,它将垂直堆叠并居中放置导航链接。</p>
  65. <p>您稍后将在我们的 CSS 教程中学到有关媒体查询和响应式 Web 设计的更多知识。</p>
  66. <p><b>请调整浏览器窗口的大小以查看效果。</b></p>
  67. </div>
  68. </body>

下拉式导航栏

如何在导航栏中添加下拉菜单。

  1. <head>
  2. <style>
  3. ul {
  4. list-style-type: none;
  5. margin: 0;
  6. padding: 0;
  7. overflow: hidden;
  8. background-color: #333;
  9. }
  10. li {
  11. float: left;
  12. }
  13. li a, .dropbtn {
  14. display: inline-block;
  15. color: white;
  16. text-align: center;
  17. padding: 14px 16px;
  18. text-decoration: none;
  19. }
  20. li a:hover, .dropdown:hover .dropbtn {
  21. background-color: red;
  22. }
  23. li.dropdown {
  24. display: inline-block;
  25. }
  26. .dropdown-content {
  27. display: none;
  28. position: absolute;
  29. background-color: #f9f9f9;
  30. min-width: 160px;
  31. box-shadow: 0px 8px 16px 0px rgba(0,0,0,0.2);
  32. z-index: 1;
  33. }
  34. .dropdown-content a {
  35. color: black;
  36. padding: 12px 16px;
  37. text-decoration: none;
  38. display: block;
  39. text-align: left;
  40. }
  41. .dropdown-content a:hover {background-color: #f1f1f1;}
  42. .dropdown:hover .dropdown-content {
  43. display: block;
  44. }
  45. </style>
  46. </head>
  47. <body>
  48. <ul>
  49. <li><a href="#home">Home</a></li>
  50. <li><a href="#news">News</a></li>
  51. <li class="dropdown">
  52. <a href="javascript:void(0)" class="dropbtn">Dropdown</a>
  53. <div class="dropdown-content">
  54. <a href="#">Link 1</a>
  55. <a href="#">Link 2</a>
  56. <a href="#">Link 3</a>
  57. </div>
  58. </li>
  59. </ul>
  60. <h1>导航栏内的下拉菜单</h1>
  61. <p>请悬停到 "Dropdown" 链接上,以查看下拉菜单。</p>
  62. </body>