サイトロゴ

Enjoy Creating
Web & Mobile Apps

MENU BOX
Webで
遊ぼ!
OPEN

ホーム

 > 

サンプルコード集

 > 

アコーディオンメニュー

アコーディオンメニュー

2021・05・26

*クリックで開閉するアコーディオンメニューです*

シンプルですが、大項目に付属している「 ▼ 」マークがメニューの開閉に合わせて回転したり、子メニューのマウスオーバー時に背景色とフォントサイズが変わったりなど、ちょっとした工夫も入れています。

使用機能:CSS・JavaScript

メニュー項目

上記のサンプルコードを掲載しています。学習用としてご自由にコピペしてお使い下さい。(※スクロールできます)

HTML・CSS・JavaScript

<!DOCTYPE html>
<html lang="ja" dir="ltr">
  <head>
    <meta charset="utf-8">
    <title></title>
    <style>
    .samplemenu {
      font-family:"游ゴシック体 Medium","游ゴシック体","游ゴシック Medium","Yu Gothic","YuGothic",sans-serif;
      padding-inline-start: 0;
      width:70%;
      margin: 1rem auto;
    }
    .samplemenu h1 {
      margin: 1.5rem;
    }
    .samplemenu ul {
      padding-inline-start: 0;
      margin-block-start:0;
      margin-block-end:0;
      list-style: none;
      cursor: pointer;

    }
    .samplemenu ul li:not(:first-child) {
      font-size: .8rem;
      background-color: lightblue;
      border-bottom: dashed thin blue;
      transition: all .4s;
    }
    .samplemenu ul li:first-child {
      font-size: 1rem;
      padding: .5rem;
      background-color: darkblue;
      color: white;
    }
    .samplemenu ul li:last-child{
      border-bottom: none;
    }
    .samplemenu ul li:not(:first-child):hover {
      background-color: rgba(173, 215, 230, 0.52);
      font-size: 1rem;
    }
    .samplesankaku {
      display:inline-block;
      transform: rotate(-90deg) scale(.5);
      transition: all .4s;
    }
    .samplesankakuactive {
      display:inline-block;
      transform: rotate(0deg) scale(.5);
      transition: all .4s;
    }
    .samplehide1 {
      opacity: 0;
      visibility: hidden;
      height: 0;
    }
    .samplehide2 {
      opacity: 0;
      visibility: hidden;
      height: 0;
    }

    .sampleactive {
      opacity: 1;
      visibility: visible;
      display: flex;
      align-items: center;
      height: 1.5rem;
      padding: .5rem;
      }
    </style>
  </head>
  <body>
    <menu class="samplemenu">
      <h1 style="font-family:'游ゴシック体 Medium','游ゴシック体','游ゴシック Medium','Yu Gothic','YuGothic',sans-serif;">メニュー項目</h1>
      <ul>
        <li id="samplemenu1"><span class="samplesankaku samplesankaku1">▼</span>MAIN MENU</li>
        <li class="samplehide1">HOME</li>
        <li class="samplehide1">ABOUT</li>
        <li class="samplehide1">CONTACT</li>
      </ul>
      <ul>
        <li id="samplemenu2"><span class="samplesankaku samplesankaku2">▼</span>お知らせ</li>
        <li class="samplehide2">最新ニュース</li>
        <li class="samplehide2">お知らせ一覧</li>
      </ul>
    </menu>
    <script>
      {
        const menu1 = document.getElementById('samplemenu1');
        const samplesankaku1 = document.querySelector('.samplesankaku1');
        const samplehidemenus1 = document.querySelectorAll('.samplehide1');

        menu1.addEventListener('click',function (event) {
          for (const samplehidemenue1 of samplehidemenus1) {
            samplehidemenue1.classList.toggle('samplehide1');
            samplehidemenue1.classList.toggle('sampleactive');
          };
          samplesankaku1.classList.toggle('samplesankakuactive');
        });

        const menu2 = document.getElementById('samplemenu2');
        const samplesankaku2 = document.querySelector('.samplesankaku2');
        const samplehidemenus2 = document.querySelectorAll('.samplehide2');

        menu2.addEventListener('click',function (event) {
          for (const samplehidemenue2 of samplehidemenus2) {
            samplehidemenue2.classList.toggle('samplehide2');
            samplehidemenue2.classList.toggle('sampleactive');
          };
          samplesankaku2.classList.toggle('samplesankakuactive');
        });
      }
    </script>
  </body>
</html>
« »