0%

Programmingプログラミングナレッジ

Posted:2018.09.17

プラグインを使わずシンプルなドロワーメニューを実装する

スマホサイトを作るときなど、グローバルナビを画面端から表示させるような、いわゆるドロワーメニューと呼ばれる形で実装するケースが多々あるかと思います。ドロワーメニュー用のプラグインなどは便利なものがすでにたくさん存在していますが、カスタマイズするときにちょっとややこしかったりもします。

 

そこで今回はjQueryを使ってシンプルなドロワーメニューを実装していきたいと思います。特に複雑な動きを求めない場合や、ドロワーメニューをカスタマイズしていきたいときにやりやすいのではないでしょうか。では早速コードを見ていきます。

【HTML】※一部省略

<body>
  <header>
    <a id="hamburger" href="javascript:void(0)">
      <span></span>
      <span></span>
      <span></span>
    </a>
  </header>
  <div class="contents">
    〜 サイトコンテンツ 〜
  </div>
  <div id="overlay">
  </div>
  <div id="drawer-menu">
    <ul>
      <li><a href="">Menu 1</a>
      </li>
      <li><a href="">Menu 2</a>
      </li>
      <li><a href="">Menu 3</a>
      </li>
      <li><a href="">Menu 4</a>
      </li>
    </ul>
    <a id="close" href="javascript:void(0)">
      <span></span>
      <span></span>
    </a>
  </div>
</body>

 

【Sass(scss)】

#hamburger {
  width: 40px;
  height: 30px;
  position: relative;
  display: block;
    span {
      width: 40px;
      height: 2px;
      background: #000;
      position: absolute;
      left: 0;
        &:first-child {
          top: 0;
        }
        &:nth-child(2) {
          top: calc(50% - 1px);
        }
        &:nth-child(3) {
          bottom: 0;
        }
    }
}
#overlay {
  width: 100%;
  height: 100vh;
  position: fixed;
  left: 0;
  top: 0;
  background: rgba(0,0,0,.7);
  z-index: 100;
  display: none;
}
#drawer-menu {
  width: 260px;
  height: 100vh;
  background: #fff;
  position: fixed;
  left: 0;
  top: 0;
  z-index: 200;
  transform: translateX(-320px);
  transition: all 0.3s ease 0s;
    &.open {
      transform: translateX(0);
    }
    ul {
      margin: 0;
      padding: 0;
      list-style-type: none;
        li {
          border-bottom: 1px solid #ccc;
            a {
              display: block;
              padding: 15px;
            }
        }
    }
    #close {
      width: 40px;
      height: 40px;
      display: block;
      position: absolute;
      right: -50px;
      top: 25px;
        span {
          width: 40px;
          height: 2px;
          background: #fff;
          position: absolute;
          left: 0;
            &:first-child {
              transform: rotate(45deg);
            }
            &:nth-child(2) {
              transform: rotate(-45deg);
            }
        }
    }
}

 

まずはHTMLとCSSでドロワーメニューの要素を作っていきます。表面に配置するので、サイトコンテンツの後にドロワーメニューを持ってきます。ドロワーメニュー本体と、背面に表示させるオーバーレイ用のスクリーン、そしてドロワーメニューの表示非表示をするハンバーガーメニューボタンと、クローズボタンを用意します。

 

それぞれにボタンにaタグを使う場合には、href属性の値に「javascript:void(0)」を設定してリンク先への遷移を無効にしておきます。

 

ドロワーメニュー本体はpositionのfixedで画面端に固定表示させた後、transformで画面外になるよう移動させておきます。そして表示されている時を示すclassを持っているときに、元の位置になるようtransformの値をリセットします。

 

また、この時にtransitionを設定しておくことでアニメーションをつけることができます。そして、jQueryでドロワーメニューが動作するように実装していきます。

【javascript】

$(function(){
  const openBtn = $("#hamburger");
  const closeBtn = $("#close");
  const overlay = $("#overlay");
  const panel = $("#drawer-menu");
  function panelOpen() {
    overlay.fadeIn('fast');
    panel.addClass('open');
  }
  function panelClose() {
    overlay.fadeOut('fast');
    panel.removeClass('open');
  }
  openBtn.on('click',function(){
    panelOpen();
  });
  closeBtn.on('click',function(){
    panelClose();
  });
  overlay.on('click',function(){
    panelClose();
  });
  $(window).on('resize',function(){
    panelClose();
  });
});

 

ドロワーメニューの表示と非表示をそれぞれ関数にしておくと、イベントごとに管理できるので便利です。動き自体はシンプルで、オーバーレイ用のスクリーンの表示非表示と、ドロワーメニュー本体のclass付与を切り替えているだけです。

 

これでシンプルなドロワーメニューが実装できます。今回のサンプルは下記にあげていますのでご参考に。

 

See the Pen simple drawer menu by designsupply (@designsupply) on CodePen.

 

プラグインを使わないことで、カスタマイズもやりやすくなったり、無駄なファイルの読み込みも減るのでぜひ試してみてはいかがでしょうか。

author
この記事を書いた人オガワ シンヤ
FacebookTwitter

DesignSupply.代表 / ディレクター・ウェブデザイナー・フロントエンドエンジニアをやっています。「ウェブとデザインでヒト・モノ・サービスを繋げ新しい価値を生み出す」をコンセプトに日々奮闘中!制作中はチョコレートが欠かせない三十路Webクリエイター。

制作のご依頼やお問い合わせ・パートナー業務提携のご相談はこちら

デザインやウェブ制作についてのご依頼やご相談、その他お問い合わせなどもお気軽にご連絡ください。フットワークの軽さやレスポンスの早さ、また豊富な経験や知識、技術を活かした対応力といったフリーランスクリエイターの強みでクライアント様、パートナー企業様のお力になります。デザインからコーディングやWordPress実装といったウェブサイト構築はもちろん、写真撮影や動画編集、コンテンツ制作からサイト運用サポートまで一括してお任せください。

ホームページ制作のご検討やウェブ運用でお悩みの経営者様や企業のウェブ担当者様をはじめ、個人で店舗を営んでいらっしゃるオーナー様、フリーで活動されているビジネスオーナー様はもちろんのこと、リソース不足でお困りの制作会社様、またクリエイターをお探しの代理店様も大歓迎です。

コンタクトをご希望の方はお手数ですが、下記よりお問い合わせフォームのページへアクセスしていただき、必要事項を入力の上メッセージを送信してください。確認でき次第すぐに折り返しご連絡致します。

こんな記事も読まれています

コメントもお気軽にどうぞ

記事に関するご質問やご意見などありましたら下記のコメントフォームよりお気軽に投稿ください。なおメールアドレスは公開されませんのでご安心ください。また、* が付いている欄は必須項目となります。

内容に問題なければ、下記の「コメントを送信する」ボタンを押してください。

CAPTCHA


ページトップへ
大阪市天王寺区のホームページ制作デザイン事務所(SOHO)DesignSupply.【デザインサプライ】