CSS 水平导航栏
行内列表项
构建水平导航栏的一种方法是,除了上一章中的“标准”代码外,还要将
ຄວາມຄິດຕະນາຮູບຮ່າງ
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 { 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- 前缀(请参见上面的例子)。您还必须指定 top
、right
、bottom
或 left
至少之一,以使粘性定位起作用。