基本的なHTMLとCSSで、シンプルな機能のドロップダウンメニューを実装する方法


この記事では、シンプルなドロップダウンメニューの実装方法を解説します。

今回ご紹介するコードは、Webページに簡単なドロップダウンメニューを実装するためのものであり、CSSとHTMLの基本的な知識があれば理解できるものです。

  • メニューの表示と非表示を制御するためにチェックボックスとラベルを使用し、CSSを使ってアニメーションとスタイリングを実現しています。
  • ハンバーガーアイコンをクリックすると、メニューがスムーズに表示され、ユーザーがナビゲーションを行えるようになります。
  • メニュー項目にホバーするとアンダーラインが表示されるなど、ユーザーエクスペリエンスを向上させるための機能も組み込まれています。

この実装はシンプルで効果的であり、Webページのユーザーインターフェースを向上させる手法の一例です。初心者の方でも、このコードをベースにカスタマイズや拡張を行うことができるでしょう。ページ内では目次の役割、またWebサイト全体のナビゲーションとしての用途にも、応用ができるかと思います。



デモページ


This is a test page for the hamburger menu. - testexplore


ソースコード



コードの解説


HTML構造

<div class="outer-menu"> <!-- メニューの外側の領域 -->
  <input type="checkbox" class="checkbox-toggle">
  <div class="hamburger"> <!-- ハンバーガーアイコン -->
    <div></div> <!-- ハンバーガーアイコンの線2本 -->
  </div>
  <div class="menu"> <!-- メニューの本体 -->
    <div> <!-- メニューコンテナ -->
      <div> <!-- メニュー内容 -->
        <ul> <!-- メニュー項目 -->
          <li><a>メニュー項目1</a></li>
          <li><a>メニュー項目2</a></li>
          <!-- 他の項目も同様に続く -->


  1. <div class="outer-menu">: メニューの外側の領域を表すラベル要素。

    • position: fixed;で固定位置に配置され、ハンバーガーアイコンを表示します。
  2. <input type="checkbox" class="checkbox-toggle">: メニューを表示・非表示にするためのチェックボックス。

  3. <div class="hamburger">: ハンバーガーアイコンのコンテナ。

    • クリックされるとメニューが表示されるトリガーとして機能します。
  4. <div class="menu">: メニューの本体部分。

    • メニュー項目が含まれ、クリックすることでウェブページへのリンクなどの操作が行えます。




CSS

基本スタイル

/* ハンバーガーアイコン */

.outer-menu .hamburger {
  position: absolute;
  top: 0;
  left: 0;
  z-index: 1;
  width: 45px;
  height: 50px;
  padding: 0.5em 1em;
  background: rgba(33, 150, 243, 0.75);
  border-radius: 0 0.12em 0.12em 0;
  cursor: pointer;
  transition: box-shadow 0.4s ease;
  backface-visibility: hidden;
  display: flex;
  align-items: center;
  justify-content: center;
}

/* ハンバーガーアイコンの線 */

.outer-menu .hamburger > div {
  position: relative;
  flex: none;
  width: 100%;
  height: 2px;
  background: #FEFEFE;
  transition: all 0.4s ease;
  display: flex;
  align-items: center;
  justify-content: center;
}
.outer-menu .hamburger > div:before,
.outer-menu .hamburger > div:after {
  content: '';
  position: absolute;
  z-index: 1;
  top: -10px;
  left: 0;
  width: 100%;
  height: 2px;
  background: inherit;
  transition: all 0.4s ease;
}
.outer-menu .hamburger > div:after {
  top: 10px;
}

/* メニュー(ハンバーガーアイコン)の配置 */

.outer-menu {
  position: fixed;
  top: 10vh;
  right: 100px;
  z-index: 1;
}

/* メニューの表示/非表示を切り替えるチェックボックス */

.outer-menu .checkbox-toggle {
  position: absolute;
  top: 0;
  left: 0;
  z-index: 2;
  cursor: pointer;
  width: 60px;
  height: 60px;
  opacity: 0;
}


メニューのデザイン

/* メニュー */

.outer-menu .menu {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  pointer-events: none;
  visibility: hidden;
  overflow: hidden;
  backface-visibility: hidden;
  outline: 1px solid transparent;
  display: flex;
  align-items: center;
  justify-content: center;
}

/* メニューのコンテナ(箱、柄) */

.outer-menu .menu > div {
  width: 200vw;
  height: 200vw;
  color: #FEFEFE;
  background: rgba(41, 98, 255, 0.97);
  border-radius: 50%;
  transition: all 0.4s ease;
  flex: none;
  transform: scale(0);
  backface-visibility: hidden;
  overflow: hidden;
  display: flex;
  align-items: center;
  justify-content: center;
}

/* メニュー内容 */

.outer-menu .menu > div > div {
  text-align: center;
  max-width: 90vw;
  max-height: 100vh;
  opacity: 0;
  transition: opacity 0.4s ease;
  overflow-y: auto;
  flex: none;
  display: flex;
  align-items: center;
  justify-content: center;
}

/* メニュー項目リスト */

.outer-menu .menu > div > div > ul {
  list-style: none;
  padding: 0 1em;
  margin: 0;
  display: block;
  max-height: 100vh;
}

/* メニュー項目 */

.outer-menu .menu > div > div > ul > li {
  padding: 0;
  margin: 1em;
  font-size: 24px;
  display: block;
}

/* メニュー項目のリンク */

.outer-menu .menu > div > div > ul > li > a {
  position: relative;
  display: inline;
  cursor: pointer;
  transition: color 0.4s ease;
}

/* メニュー項目のリンクホバー時のフォント色 */

.outer-menu .menu > div > div > ul > li > a:hover {
  color: #e5e5e5;
}

/* メニュー項目のリンクホバー時のアンダーライン */

.outer-menu .menu > div > div > ul > li > a:hover:after {
  width: 100%;
}

/* メニュー項目のリンクアンダーライン */

.outer-menu .menu > div > div > ul > li > a:after {
  content: '';
  position: absolute;
  z-index: 1;
  bottom: -0.15em;
  left: 0;
  width: 0;
  height: 2px;
  background: #e5e5e5;
  transition: width 0.4s ease;
}


メニューのアニメーション

/* チェックボックスがチェックされた時のハンバーガーアイコンの回転アニメーション */

.outer-menu .checkbox-toggle:checked + .hamburger > div {
  transform: rotate(135deg);
}

/* チェックボックスがチェックされた時のハンバーガーアイコンの線の回転アニメーション */

.outer-menu .checkbox-toggle:checked + .hamburger > div:before,
.outer-menu .checkbox-toggle:checked + .hamburger > div:after {
  top: 0;
  transform: rotate(90deg);
}
.outer-menu .checkbox-toggle:checked + .hamburger > div:after {
  opacity: 0;
}

/* チェックボックスがチェックされた時のメニューの表示 */

.outer-menu .checkbox-toggle:checked ~ .menu {
  pointer-events: auto;
  visibility: visible;
}

/* チェックボックスがチェックされた時のメニューの拡大アニメーション */

.outer-menu .checkbox-toggle:checked ~ .menu > div {
  transform: scale(1);
  transition-duration: 0.75s;
}

/* チェックボックスがチェックされた時のメニュー項目のフェードイン */

.outer-menu .checkbox-toggle:checked ~ .menu > div > div {
  opacity: 1;
  transition: opacity 0.4s ease 0.4s;
}

/* ハンバーガーアイコンにホバー時の影の追加 */

.outer-menu .checkbox-toggle:hover + .hamburger {
  box-shadow: inset 0 0 10px rgba(0, 0, 0, 0.1);
}

/* チェックボックスがチェックされた時のハンバーガーアイコンの回転アニメーション2 */

.outer-menu .checkbox-toggle:checked:hover + .hamburger > div {
  transform: rotate(225deg);
}


動作仕様

  • .checkbox-toggleがクリックされると、.menuが表示され、ハンバーガーアイコンがアニメーションしてメニューを開きます。

  • メニュー項目はリンクのリストで、ホバーやクリック時にスタイルが変化します。




まとめ

CSSの知識があれば誰でも理解できるシンプルなドロップダウンメニューの実装方法を紹介しました。
チェックボックスとラベルを使用してメニューを制御し、CSSを活用してアニメーションとスタイリングを行い、ユーザーエクスペリエンスを向上させました。

このコードは、基本的なHTMLとCSSの知識を持っている人にとって理解しやすい、シンプルなドロップダウンメニューの実装例です。
初心者でも簡単にカスタマイズや拡張が可能です。ウェブ開発の基本から始めたい方におすすめの実践例です。