CSS 水平导航栏

水平导航栏

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

行内列表项

构建水平导航栏的一种方法是,除了上一章中的“标准”代码外,还要将

  • 元素指定为 inline:

    ຄວາມຄິດຕະນາຮູບຮ່າງ

    li {
      display: inline;
    }
    

    亲自试一试

    ຄຳອະທິບາຍຄວາມຄວາມຄິດ:

    display: inline; -默认情况下,

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

  • ສິ່ງທີ່ພັດທະນາ

    ອີກວິທີໜຶ່ງທີ່ສາມາດສ້າງບາງຄູ່ນພາບກາກບັນຍາບັນບາງລາຍການລະບາຍສຳພັນແມ່ນການກຳນົດ <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;):

    ຄວາມຄິດຕະນາຮູບຮ່າງ

    
    

    亲自试一试

    边框分隔栏

    border-right 属性添加到

  • ,以创建链接分隔符:

    ຄວາມຄິດຕະນາຮູບຮ່າງ

    /* 为所有列表项添加灰色右边框,最后一项(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;
    }
    

    亲自试一试

    粘性导航栏

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

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

      ຄວາມຄິດຕະນາຮູບຮ່າງ

      ul {
        position: -webkit-sticky; /* Safari */
        position: sticky;
        top: 0;
      }
      

      亲自试一试

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

    更多实例

    响应式的上导航栏
    如何使用 CSS 媒体查询来创建响应式顶部导航。
    响应式的侧导航栏
    如何使用 CSS 媒体查询来创建响应式侧导航。
    下拉式导航栏
    如何在导航栏中添加下拉菜单。