CSS 水平导航栏


水平导航栏

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


行内列表项

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

  1. <!DOCTYPE html>
  2. <html>
  3. <head>
  4. <style>
  5. ul {
  6. list-style-type: none;
  7. margin: 0;
  8. padding: 0;
  9. }
  10. li {
  11. display: inline;
  12. }
  13. </style>
  14. </head>
  15. <body>
  16. <ul>
  17. <li><a href="#home">首页</a></li>
  18. <li><a href="#news">新闻</a></li>
  19. <li><a href="#contact">联系方式</a></li>
  20. <li><a href="#about">关于我们</a></li>
  21. </ul>
  22. </body>
  23. </html>
例子解释:

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


浮动列表项

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

  1. <!DOCTYPE html>
  2. <html>
  3. <head>
  4. <style>
  5. ul {
  6. list-style-type: none;
  7. margin: 0;
  8. padding: 0;
  9. overflow: hidden;
  10. }
  11. li {
  12. float: left;
  13. }
  14. li a {
  15. display: block;
  16. padding: 8px;
  17. background-color: #dddddd;
  18. }
  19. </style>
  20. </head>
  21. <body>
  22. <ul>
  23. <li><a href="#home">首页</a></li>
  24. <li><a href="#news">新闻</a></li>
  25. <li><a href="#contact">联系方式</a></li>
  26. <li><a href="#about">关于我们</a></li>
  27. </ul>
  28. <p><b>注释:</b>如果未指定 !DOCTYPE,则浮动项目可能会产生意外结果。</p>
  29. <p>背景色被添加到链接以显示链接区域。整个链接区域都是可单击的,而不仅仅是文本。</p>
  30. <p><b>注释:</b>overflow:hidden 被添加到 ul 元素,以防止 li 元素超出列表。</p>
  31. </body>
  32. </html>
例子解释:
  • float: left; - 使用 float 使块元素滑动为彼此相邻
  • display: block; - 将链接显示为块元素可以使整个链接区域都可单击(不仅是文本),而且允许我们指定填充(如果需要,还可以指定高度,宽度,边距等)
  • padding: 8px; - 使块元素更美观
  • background-color: #dddddd; - 为每个元素添加灰色背景色

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

  1. <!DOCTYPE html>
  2. <html>
  3. <head>
  4. <style>
  5. ul {
  6. list-style-type: none;
  7. margin: 0;
  8. padding: 0;
  9. overflow: hidden;
  10. background-color: #dddddd;
  11. }
  12. li {
  13. float: left;
  14. }
  15. li a {
  16. display: block;
  17. padding: 8px;
  18. }
  19. </style>
  20. </head>
  21. <body>
  22. <ul>
  23. <li><a href="#home">首页</a></li>
  24. <li><a href="#news">新闻</a></li>
  25. <li><a href="#contact">联系方式</a></li>
  26. <li><a href="#about">关于我们</a></li>
  27. </ul>
  28. <p>将背景色添加到列表中(而不是每个链接),以创建全宽的背景色。</p>
  29. <p><b>注释:</b>overflow:hidden 被添加到 ul 元素,以防止 li 元素超出列表。</p>
  30. </body>
  31. </html>

水平导航条实例

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

  1. <!DOCTYPE html>
  2. <html>
  3. <head>
  4. <style>
  5. ul {
  6. list-style-type: none;
  7. margin: 0;
  8. padding: 0;
  9. overflow: hidden;
  10. background-color: #333;
  11. }
  12. li {
  13. float: left;
  14. }
  15. li a {
  16. display: block;
  17. color: white;
  18. text-align: center;
  19. padding: 14px 16px;
  20. text-decoration: none;
  21. }
  22. li a:hover {
  23. background-color: #111;
  24. }
  25. </style>
  26. </head>
  27. <body>
  28. <ul>
  29. <li><a class="active" href="#home">首页</a></li>
  30. <li><a href="#news">新闻</a></li>
  31. <li><a href="#contact">联系方式</a></li>
  32. <li><a href="#about">关于我们</a></li>
  33. </ul>
  34. </body>
  35. </html>

活动/当前导航链接

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

代码如下:

  1. <!DOCTYPE html>
  2. <html>
  3. <head>
  4. <style>
  5. ul {
  6. list-style-type: none;
  7. margin: 0;
  8. padding: 0;
  9. overflow: hidden;
  10. background-color: #333;
  11. }
  12. li {
  13. float: left;
  14. }
  15. li a {
  16. display: block;
  17. color: white;
  18. text-align: center;
  19. padding: 14px 16px;
  20. text-decoration: none;
  21. }
  22. li a:hover:not(.active) {
  23. background-color: #111;
  24. }
  25. .active {
  26. background-color: #04AA6D;
  27. }
  28. </style>
  29. </head>
  30. <body>
  31. <ul>
  32. <li><a class="active" href="#home">首页</a></li>
  33. <li><a href="#news">新闻</a></li>
  34. <li><a href="#contact">联系方式</a></li>
  35. <li><a href="#about">关于我们</a></li>
  36. </ul>
  37. </body>
  38. </html>

右对齐链接

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

代码如下:

  1. <!DOCTYPE html>
  2. <html>
  3. <head>
  4. <style>
  5. ul {
  6. list-style-type: none;
  7. margin: 0;
  8. padding: 0;
  9. overflow: hidden;
  10. background-color: #333;
  11. }
  12. li {
  13. float: left;
  14. }
  15. li a {
  16. display: block;
  17. color: white;
  18. text-align: center;
  19. padding: 14px 16px;
  20. text-decoration: none;
  21. }
  22. li a:hover:not(.active) {
  23. background-color: #111;
  24. }
  25. .active {
  26. background-color: #04AA6D;
  27. }
  28. </style>
  29. </head>
  30. <body>
  31. <ul>
  32. <li><a href="#home">首页</a></li>
  33. <li><a href="#news">新闻</a></li>
  34. <li><a href="#contact">联系方式</a></li>
  35. <li style="float:right"><a class="active" href="#about">关于我们</a></li>
  36. </ul>
  37. </body>
  38. </html>

边框分隔栏

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

  1. <!DOCTYPE html>
  2. <html>
  3. <head>
  4. <style>
  5. ul {
  6. list-style-type: none;
  7. margin: 0;
  8. padding: 0;
  9. overflow: hidden;
  10. background-color: #333;
  11. }
  12. li {
  13. float: left;
  14. border-right:1px solid #bbb;
  15. }
  16. li:last-child {
  17. border-right: none;
  18. }
  19. li a {
  20. display: block;
  21. color: white;
  22. text-align: center;
  23. padding: 14px 16px;
  24. text-decoration: none;
  25. }
  26. li a:hover:not(.active) {
  27. background-color: #111;
  28. }
  29. .active {
  30. background-color: #04AA6D;
  31. }
  32. </style>
  33. </head>
  34. <body>
  35. <ul>
  36. <li><a class="active" href="javascript:void(0)">首页</a></li>
  37. <li><a href="javascript:void(0)">新闻</a></li>
  38. <li><a href="javascript:void(0)">联系方式</a></li>
  39. <li style="float:right"><a href="javascript:void(0)">关于我们</a></li>
  40. </ul>
  41. </body>
  42. </html>

固定的导航条

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

固定在顶部
  1. <!DOCTYPE html>
  2. <html>
  3. <head>
  4. <style>
  5. html, body {
  6. font-family: Verdana,sans-serif;
  7. font-size: 15px;
  8. line-height: 1.5
  9. }
  10. body {
  11. margin: 0;
  12. }
  13. ul {
  14. list-style-type: none;
  15. margin: 0;
  16. padding: 0;
  17. overflow: hidden;
  18. background-color: #333;
  19. position: fixed;
  20. top: 0;
  21. width: 100%;
  22. }
  23. li {
  24. float: left;
  25. }
  26. li a {
  27. display: block;
  28. color: white;
  29. text-align: center;
  30. padding: 14px 16px;
  31. text-decoration: none;
  32. }
  33. li a:hover:not(.active) {
  34. background-color: #111;
  35. }
  36. .active {
  37. background-color: #04AA6D;
  38. }
  39. </style>
  40. </head>
  41. <body>
  42. <ul>
  43. <li><a class="active" href="#home">首页</a></li>
  44. <li><a href="#news">新闻</a></li>
  45. <li><a href="#contact">联系方式</a></li>
  46. </ul>
  47. <div style="padding:20px;margin-top:30px;background-color:#1abc9c;height:1000px;">
  48. <h1>顶部固定导航条</h1>
  49. <h2>滚动时,导航条将停留在页面顶部</h2>
  50. <p>这是一些文本,这是一些文本</p>
  51. <p>这是一些文本,这是一些文本</p>
  52. <p>这是一些文本,这是一些文本</p>
  53. <p>这是一些文本,这是一些文本</p>
  54. <p>这是一些文本,这是一些文本</p>
  55. <p>这是一些文本,这是一些文本</p>
  56. <p>这是一些文本,这是一些文本</p>
  57. <p>这是一些文本,这是一些文本</p>
  58. <p>这是一些文本,这是一些文本</p>
  59. <p>这是一些文本,这是一些文本</p>
  60. <p>这是一些文本,这是一些文本</p>
  61. <p>这是一些文本,这是一些文本</p>
  62. <p>这是一些文本,这是一些文本</p>
  63. <p>这是一些文本,这是一些文本</p>
  64. </div>
  65. </body>
  66. </html>
固定在底部
  1. <!DOCTYPE html>
  2. <html>
  3. <head>
  4. <style>
  5. html, body {
  6. font-family: Verdana,sans-serif;
  7. font-size: 15px;
  8. line-height: 1.5
  9. }
  10. body {
  11. margin: 0;
  12. }
  13. ul {
  14. list-style-type: none;
  15. margin: 0;
  16. padding: 0;
  17. overflow: hidden;
  18. background-color: #333;
  19. position: fixed;
  20. bottom: 0;
  21. width: 100%;
  22. }
  23. li {
  24. float: left;
  25. }
  26. li a {
  27. display: block;
  28. color: white;
  29. text-align: center;
  30. padding: 14px 16px;
  31. text-decoration: none;
  32. }
  33. li a:hover:not(.active) {
  34. background-color: #111;
  35. }
  36. .active {
  37. background-color: #04AA6D;
  38. }
  39. </style>
  40. </head>
  41. <body>
  42. <ul>
  43. <li><a class="active" href="#home">首页</a></li>
  44. <li><a href="#news">新闻</a></li>
  45. <li><a href="#contact">联系方式</a></li>
  46. </ul>
  47. <div style="padding:20px;;background-color:#1abc9c;height:1000px;">
  48. <h1>底部固定导航条</h1>
  49. <h2>滚动时,导航条将停留在页面底部</h2>
  50. <p>这是一些文本,这是一些文本</p>
  51. <p>这是一些文本,这是一些文本</p>
  52. <p>这是一些文本,这是一些文本</p>
  53. <p>这是一些文本,这是一些文本</p>
  54. <p>这是一些文本,这是一些文本</p>
  55. <p>这是一些文本,这是一些文本</p>
  56. <p>这是一些文本,这是一些文本</p>
  57. <p>这是一些文本,这是一些文本</p>
  58. <p>这是一些文本,这是一些文本</p>
  59. <p>这是一些文本,这是一些文本</p>
  60. <p>这是一些文本,这是一些文本</p>
  61. <p>这是一些文本,这是一些文本</p>
  62. <p>这是一些文本,这是一些文本</p>
  63. </div>
  64. </body>
  65. </html>

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


灰色水平导航条

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

代码如下:

  1. <!DOCTYPE html>
  2. <html>
  3. <head>
  4. <style>
  5. ul {
  6. list-style-type: none;
  7. margin: 0;
  8. padding: 0;
  9. overflow: hidden;
  10. border: 1px solid #e7e7e7;
  11. background-color: #f3f3f3;
  12. }
  13. li {
  14. float: left;
  15. }
  16. li a {
  17. display: block;
  18. color: #666;
  19. text-align: center;
  20. padding: 14px 16px;
  21. text-decoration: none;
  22. }
  23. li a:hover:not(.active) {
  24. background-color: #ddd;
  25. }
  26. li a.active {
  27. color: white;
  28. background-color: #4CAF50;
  29. }
  30. </style>
  31. </head>
  32. <body>
  33. <ul>
  34. <li><a class="active" href="javascript:void(0)">首页</a></li>
  35. <li><a href="javascript:void(0)">新闻</a></li>
  36. <li><a href="javascript:void(0)">联系方式</a></li>
  37. <li><a href="javascript:void(0)">关于我们</a></li>
  38. </ul>
  39. </body>
  40. </html>

粘性导航条

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

实例
  1. <!DOCTYPE html>
  2. <html>
  3. <head>
  4. <style>
  5. body {
  6. font-size: 28px;
  7. }
  8. ul {
  9. list-style-type: none;
  10. margin: 0;
  11. padding: 0;
  12. overflow: hidden;
  13. background-color: #333;
  14. position: -webkit-sticky; /* Safari */
  15. position: sticky;
  16. top: 0;
  17. }
  18. li {
  19. float: left;
  20. }
  21. li a {
  22. display: block;
  23. color: white;
  24. text-align: center;
  25. padding: 14px 16px;
  26. text-decoration: none;
  27. }
  28. li a:hover {
  29. background-color: #111;
  30. }
  31. .active {
  32. background-color: #4CAF50;
  33. }
  34. </style>
  35. </head>
  36. <body>
  37. <div class="header">
  38. <h3>向下滚动</h3>
  39. <p>请向下滚动以查看粘性效果。</p>
  40. </div>
  41. <ul>
  42. <li><a class="active" href="#home">Home</a></li>
  43. <li><a href="#news">News</a></li>
  44. <li><a href="#contact">Contact</a></li>
  45. </ul>
  46. <h3>粘性导航条实例</h3>
  47. <p>当你滚动页面将导航条滚到顶部时,导航条将粘着顶部。</p>
  48. <p>这是一些文本确保页面能够滚动.这是一些文本确保页面能够滚动.这是一些文本确保页面能够滚动.这是一些文本确保页面能够滚动.这是一些文本确保页面能够滚动.这是一些文本确保页面能够滚动.这是一些文本确保页面能够滚动.这是一些文本确保页面能够滚动.这是一些文本确保页面能够滚动.这是一些文本确保页面能够滚动.</p>
  49. <p>这是一些文本确保页面能够滚动.这是一些文本确保页面能够滚动.这是一些文本确保页面能够滚动.这是一些文本确保页面能够滚动.这是一些文本确保页面能够滚动.这是一些文本确保页面能够滚动.这是一些文本确保页面能够滚动.这是一些文本确保页面能够滚动.这是一些文本确保页面能够滚动.这是一些文本确保页面能够滚动.</p>
  50. <p>这是一些文本确保页面能够滚动.这是一些文本确保页面能够滚动.这是一些文本确保页面能够滚动.这是一些文本确保页面能够滚动.这是一些文本确保页面能够滚动.这是一些文本确保页面能够滚动.这是一些文本确保页面能够滚动.这是一些文本确保页面能够滚动.这是一些文本确保页面能够滚动.这是一些文本确保页面能够滚动.</p>
  51. <p>这是一些文本确保页面能够滚动.这是一些文本确保页面能够滚动.这是一些文本确保页面能够滚动.这是一些文本确保页面能够滚动.这是一些文本确保页面能够滚动.这是一些文本确保页面能够滚动.这是一些文本确保页面能够滚动.这是一些文本确保页面能够滚动.这是一些文本确保页面能够滚动.这是一些文本确保页面能够滚动.</p>
  52. <p>这是一些文本确保页面能够滚动.这是一些文本确保页面能够滚动.这是一些文本确保页面能够滚动.这是一些文本确保页面能够滚动.这是一些文本确保页面能够滚动.这是一些文本确保页面能够滚动.这是一些文本确保页面能够滚动.这是一些文本确保页面能够滚动.这是一些文本确保页面能够滚动.这是一些文本确保页面能够滚动.</p>
  53. <p>这是一些文本确保页面能够滚动.这是一些文本确保页面能够滚动.这是一些文本确保页面能够滚动.这是一些文本确保页面能够滚动.这是一些文本确保页面能够滚动.这是一些文本确保页面能够滚动.这是一些文本确保页面能够滚动.这是一些文本确保页面能够滚动.这是一些文本确保页面能够滚动.这是一些文本确保页面能够滚动.</p>
  54. </body>
  55. </html>

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


分类导航