如何创建:可悬停的下拉菜单

学习如何使用 CSS 创建可悬停的下拉菜单。

下拉菜单

下拉菜单是一种可切换的菜单,允许用户从预定义列表中选择一个值:

Spróbuj sam

创建可悬停的下拉菜单

创建一个下拉菜单,当用户将鼠标移动到元素上时显示该菜单。

第一步 - 添加 HTML:

<div class="dropdown">
  <button class="dropbtn">Dropdown</button>
  <div class="dropdown-content">
    <a href="#">Link 1</a>
    <a href="#">Link 2</a>
    <a href="#">Link 3</a>
  </div>
</div>

Przykład wyjaśnienia:

使用任何元素打开下拉菜单,例如 <button>、<a> 或 <p> 元素。

使用容器元素(如 <div>)创建下拉菜单,并在其中添加下拉菜单链接。

使用 <div> 元素将按钮和 <div> 包装起来,以便使用 CSS 正确定位下拉菜单。

第二步 - 添加 CSS:

/* 下拉按钮 */
.dropbtn {
  background-color: #04AA6D;
  color: white;
  padding: 16px;
  font-size: 16px;
  border: none;
}
/* 容器<div> - 用于定位下拉菜单内容 */
.dropdown {
  position: relative;
  display: inline-block;
}
/* Zawartość rozwijanej listy (domyślnie ukryta) */
.dropdown-content {
  display: none;
  position: absolute;
  background-color: #f1f1f1;
  min-width: 160px;
  box-shadow: 0px 8px 16px 0px rgba(0,0,0,0.2);
  z-index: 1;
}
/* Linki w rozwijanej liście */
.dropdown-content a {
  color: black;
  padding: 12px 16px;
  text-decoration: none;
  display: block;
}
/* Zmiana koloru linków w rozwijanej liście podczas najechania myszą */
.dropdown-content a:hover {background-color: #ddd;}
/* Wyświetlanie rozwijanej listy przy najechaniu myszą */
.dropdown:hover .dropdown-content {display: block;}
/* Zmiana koloru tła przycisku rozwijanej listy podczas wyświetlania zawartości */
.dropdown:hover .dropbtn {background-color: #3e8e41;}

Spróbuj sam

Przykład wyjaśnienia:

Ustawiliśmy styl przycisku rozwijanej listy za pomocą koloru tła, wewnętrznych marginesów itp.

.dropdown klasy position:relative, gdy chcemy umieścić zawartość rozwijanej listy bezpośrednio pod przyciskiem rozwijanej listy (używając position:absolute)

.dropdown-content Klasa zawiera rzeczywistą rozwijaną listę. Domyślnie jest ukryta i będzie wyświetlana przy najechaniu myszą (patrz niżej). Proszę, swobodnie zmieniać to ustawienie. Wskazówka: Jeśli chcesz, aby szerokość zawartości rozwijanej listy była równa szerokości przycisku rozwijanej listy, ustaw szerokość na 100% (i ustaw overflow:auto aby włączyć przewijanie na małych ekranach).

Nie używamy krawędzi, ale zamiast tego box-shadow Atrybuty, aby rozwijana lista wyglądała jak karta. Używamy również z-index Umieść rozwijaną listę przed innymi elementami.

:hover Wybieracz jest używany do wyświetlenia rozwijanej listy, gdy użytkownik przenosi mysz nad przyciskiem rozwijanej listy.

Rozwijana lista wyśrodkowana do prawej

Spróbuj sam

Rozwijana lista w pasku nawigacyjnym

Spróbuj sam

Strony związane

Tutorial:Menu rozwijane CSS

Tutorial:Jak utworzyć klikalne menu rozwijane