2021.12.22|JavaScript(jQuery)

レスポンシブ・デザインに対応しているハンバーガーメニュー jQuery「drawer menu」の設定方法

レスポンシブ・デザインに対応しているハンバーガーメニュー jQuery「drawer menu」の設定方法

レスポンシブ・デザインに対応しているハンバーガーメニューを実装するには、jQueryライブラリを使うことによって設定できます。
ハンバーガーメニューは、グローバルナビゲーションのひとつでもありレスポンシブ・デザイン対応の代表的なナビゲーションです。左右の限られたスペースに配置することでファーストビューを綺麗に収めることができます。

レスポンシブ・デザインに対応しているハンバーガーメニューを実装するjQueryプラグイン「drawer menu Plugin」の設定方法を解説します。

レスポンシブ・デザインに対応しているハンバーガーメニューの設定方法

1.jQueryライブラリをダウンロード

下記からJavaScriptライブラリ、のダウンロードを行ってください。
jqueryライブラリダウンロード
drawer menu Pluginダウンロード

2.html、cssファイルを作成

html、cssファイルを作成します。

htmlファイルに記述
<!-- header -->
<header role="banner" class="global-header">
<div class="assist-nav">
<ul>
<li class="home">
<a href="http://www.kingsite.jp/"><big>WEBデザイナーブログ</big><small>ウェブデザイナーのお仕事</small></a>
</li>
</ul>
</div>
<button type="button" class="drawer-toggle drawer-hamburger">
<span class="sr-only">toggle navigation</span>
<span class="drawer-hamburger-icon"></span>
</button>
<nav class="drawer-nav" role="navigation">
<div class="drawer-menu">
<ul>
<li><a href="">グローバルメニュー01</a></li>
<li><a href="">グローバルメニュー02</a></li>
<li><a href="">グローバルメニュー03</a></li>
<li><a href="">グローバルメニュー04</a></li>
<li><a href="">グローバルメニュー05</a></li>
<li><a href="">グローバルメニュー06</a></li>
<li><a href="">グローバルメニュー07</a></li>
</ul>
</div>
<div class="drawer-menu-sub">
<ul>
<li><a href="">お問い合わせ</a></li>
<li><a href="">03-000-0000<small>(通話無料)</small></a></li>
</ul>
</div>
</nav>
</header>
<!-- header end -->
cssファイルに記述
.global-header {
    position: fixed;
    z-index: 10000;
    top: 0;
    left: 0;
    width: 100%;
    height: 60px;
    background: transparent;
    transition: all .8s ease;
	background-color: rgba(255,255,255,0.8);
	border-bottom:1px solid #CCC;
}
.global-header .assist-nav {
    padding: 0 1.5em;
}
.global-header .assist-nav ul {
    padding: 0;
    margin: 0;
}
.global-header .assist-nav ul li {
    list-style: none;
    display: inline-block;
    vertical-align: middle;
}
.global-header .assist-nav ul li a {
    color: #333;
    text-decoration: none;
}
.global-header .assist-nav ul li a span {
    vertical-align: top;
}
.global-header .assist-nav ul li .translate {
    margin-left: 1em;
}
.global-header .assist-nav ul li .translate ul li {
    display: block;
    text-align: center;
}
.global-header .assist-nav ul li .translate ul li:not(:last-child) {
    border-bottom: 1px solid #333;
}
.global-header .assist-nav ul li .translate ul li:not(:last-child) a {
    line-height: 1em;
}
.global-header .assist-nav ul li .translate span {
    display: none;
}
.global-header .assist-nav ul .home a {
    line-height:60px;
    position: relative;
}
.global-header .assist-nav ul .home a strong {
    font-weight: 400;
}
.global-header .assist-nav ul .home a small {
    display: inline-block;
    position: relative;
    bottom: .05em;
    left: 0;
    margin-left: .25em;
}
.drawer-open {
    overflow: hidden!important;
}
.drawer-nav {
    position: fixed;
    z-index: 2;
    top: 0;
    overflow: hidden;
    width: 280px;
    height: 100%;
    color: #222;
    background-color: #fff;
}
.drawer-menu {
    margin: 0;
    padding: 0;
    list-style: none;
}
.drawer-menu ul{
	width:100%;
	border-top:1px solid #CCC;
}
.drawer-menu ul li{
	font-size:90%;
	border-bottom:1px solid #CCC;
}
.drawer-menu ul li a{
	display:block;
	padding:5%;
}
.drawer-menu-sub {
    margin: 0;
    padding: 0;
    list-style: none;
}
.drawer-menu-sub ul{
	width:100%;
}
.drawer-menu-sub ul li{
	font-size:90%;
	border-bottom:1px solid #CCC;
	background-color:#5ac2a0;
}
.drawer-menu-sub ul li a{
	color:#FFF;
	display:block;
	padding:5%;
}
.drawer-overlay {
    position: fixed;
    z-index: 1;
    top: 0;
    left: 0;
    display: none;
    width: 100%;
    height: 100%;
    background-color: rgba(0,0,0,.2);
}
.drawer-open .drawer-overlay {
    display: block;
}
.drawer--top .drawer-nav {
    top: -100%;
    left: 0;
    width: 100%;
    height: auto;
    max-height: 100%;
    -webkit-transition: top 0.6s cubic-bezier(.19,1,.22,1);
    transition: top 0.6s cubic-bezier(.19,1,.22,1);
}
.drawer--top.drawer-open .drawer-nav {
    top: 0;
}
.drawer--top .drawer-hamburger,
.drawer--top.drawer-open .drawer-hamburger {
    right: 0;
}
.drawer--left .drawer-nav {
    left: -280px;
    -webkit-transition: left 0.6s cubic-bezier(.19,1,.22,1);
    transition: left 0.6s cubic-bezier(.19,1,.22,1);
}
.drawer--left .drawer-hamburger,
.drawer--left.drawer-open .drawer-nav,
.drawer--left.drawer-open .drawer-navbar .drawer-hamburger {
    left: 0;
}
.drawer--left.drawer-open .drawer-hamburger {
    left: 280px;
}
.drawer--right .drawer-nav {
    right: -280px;
    -webkit-transition: right 0.6s cubic-bezier(.19,1,.22,1);
    transition: right 0.6s cubic-bezier(.19,1,.22,1);
}
.drawer--right .drawer-hamburger,
.drawer--right.drawer-open .drawer-nav,
.drawer--right.drawer-open .drawer-navbar .drawer-hamburger {
    right: 0;
}
.drawer--right.drawer-open .drawer-hamburger {
    right: 280px;
}
.drawer-hamburger {
    position: fixed;
    z-index: 4;
    top: 0;
    display: block;
    box-sizing: content-box;
    width: 2rem;
    padding: 18px 0.75rem 30px;
    -webkit-transition: all 0.6s cubic-bezier(.19,1,.22,1);
    transition: all 0.6s cubic-bezier(.19,1,.22,1);
    -webkit-transform: translateZ(0);
    transform: translateZ(0);
    border: 0;
    outline: 0;
    background-color: transparent;
}
.drawer-hamburger:hover {
    cursor: pointer;
    background-color: transparent;
}
.drawer-hamburger-icon {
    position: relative;
    display: block;
    margin-top: 10px;
}
.drawer-hamburger-icon,
.drawer-hamburger-icon:after,
.drawer-hamburger-icon:before {
    width: 100%;
    height: 2px;
    -webkit-transition: all 0.6s cubic-bezier(.19,1,.22,1);
    transition: all 0.6s cubic-bezier(.19,1,.22,1);
    background-color: #222;
}
.drawer-hamburger-icon:after,
.drawer-hamburger-icon:before {
    position: absolute;
    top: -10px;
    left: 0;
    content: " ";
}
.drawer-hamburger-icon:after {
    top: 10px;
}
.drawer-open .drawer-hamburger-icon {
    background-color: transparent;
}
.drawer-open .drawer-hamburger-icon:after,
.drawer-open .drawer-hamburger-icon:before {
    top: 0;
}
.drawer-open .drawer-hamburger-icon:before {
    -webkit-transform: rotate(45deg);
    transform: rotate(45deg);
}
.drawer-open .drawer-hamburger-icon:after {
    -webkit-transform: rotate(-45deg);
    transform: rotate(-45deg);
}
.sr-only {
    position: absolute;
    overflow: hidden;
    clip: rect(0,0,0,0);
    width: 1px;
    height: 1px;
    margin: -1px;
    padding: 0;
    border: 0;
}
.sr-only-focusable:active,
.sr-only-focusable:focus {
    position: static;
    overflow: visible;
    clip: auto;
    width: auto;
    height: auto;
    margin: 0;
}
.drawer--sidebar,
.drawer--sidebar .drawer-contents {
    background-color: #fff;
}
@media screen and (max-width:767px) {
.global-header .assist-nav ul .home a small {
	display:none;
}
.drawer-menu ul li a{
	display:block;
	padding:1% 5% 1% 5%;
}
.drawer-menu-sub ul li a{
	color:#FFF;
	display:block;
	padding:1% 5% 1% 5%;
}
}
@media (min-width:64em) {
    .drawer--sidebar .drawer-hamburger {
        display: none;
        visibility: hidden;
    }
    .drawer--sidebar .drawer-nav {
        display: block;
        -webkit-transform: none;
        transform: none;
        position: fixed;
        width: 12.5rem;
        height: 100%;
    }
    .drawer--sidebar.drawer--left .drawer-nav {
        left: 0;
        border-right: 1px solid #ddd;
    }
    .drawer--sidebar.drawer--left .drawer-contents {
        margin-left: 12.5rem;
    }
    .drawer--sidebar.drawer--right .drawer-nav {
        right: 0;
        border-left: 1px solid #ddd;
    }
    .drawer--sidebar.drawer--right .drawer-contents {
        margin-right: 12.5rem;
    }
    .drawer--sidebar .drawer-container {
        max-width: 48rem;
    }
}
@media (min-width:75em) {
    .drawer--sidebar .drawer-nav {
        width: 16.25rem;
    }
    .drawer--sidebar.drawer--left .drawer-contents {
        margin-left: 16.25rem;
    }
    .drawer--sidebar.drawer--right .drawer-contents {
        margin-right: 16.25rem;
    }
    .drawer--sidebar .drawer-container {
        max-width: 60rem;
    }
}
.drawer--navbarTopGutter {
    padding-top: 3.75rem;
}
.drawer-navbar .drawer-navbar-header {
    border-bottom: 1px solid #ddd;
    background-color: #fff;
}
.drawer-navbar {
    z-index: 3;
    top: 0;
    width: 100%;
}
.drawer-navbar--fixed {
    position: fixed;
}
.drawer-navbar-header {
    position: relative;
    z-index: 3;
    box-sizing: border-box;
    width: 100%;
    height: 3.75rem;
    padding: 0 0.75rem;
    text-align: center;
}
.drawer-navbar .drawer-brand {
    line-height: 3.75rem;
    display: inline-block;
    padding-top: 0;
    padding-bottom: 0;
    text-decoration: none;
}
.drawer-navbar .drawer-brand:hover {
    background-color: transparent;
}
.drawer-navbar .drawer-nav {
    padding-top: 3.75rem;
}
.drawer-navbar .drawer-menu {
    padding-bottom: 7.5rem;
}
@media (min-width:64em) {
    .drawer-navbar {
        height: 3.75rem;
        border-bottom: 1px solid #ddd;
        background-color: #fff;
    }
    .drawer-navbar .drawer-navbar-header {
        position: relative;
        display: block;
        float: left;
        width: auto;
        padding: 0;
        border: 0;
    }
    .drawer-navbar .drawer-menu--right {
        float: right;
    }
    .drawer-navbar .drawer-menu li {
        float: left;
    }
    .drawer-navbar .drawer-menu-item {
        line-height: 3.75rem;
        padding-top: 0;
        padding-bottom: 0;
    }
    .drawer-navbar .drawer-hamburger {
        display: none;
    }
    .drawer-navbar .drawer-nav {
        position: relative;
        left: 0;
        overflow: visible;
        width: auto;
        height: 3.75rem;
        padding-top: 0;
        -webkit-transform: translateZ(0);
        transform: translateZ(0);
    }
    .drawer-navbar .drawer-menu {
        padding: 0;
    }
    .drawer-navbar .drawer-dropdown-menu {
        position: absolute;
        width: 16.25rem;
        border: 1px solid #ddd;
    }
    .drawer-navbar .drawer-dropdown-menu-item {
        padding-left: 0.75rem;
    }
}
.drawer-dropdown-menu {
    display: none;
    box-sizing: border-box;
    width: 100%;
    margin: 0;
    padding: 0;
    background-color: #fff;
}
.drawer-dropdown-menu > li {
    width: 100%;
    list-style: none;
}
.drawer-dropdown-menu-item {
    line-height: 3.75rem;
    display: block;
    padding: 0 0.75rem 0 1.5rem;
    text-decoration: none;
    color: #222;
}
.drawer-dropdown-menu-item:hover {
    text-decoration: underline;
    color: #555;
    background-color: transparent;
}
.drawer-dropdown.open > .drawer-dropdown-menu {
    display: block;
}
.drawer-dropdown .drawer-caret {
    display: inline-block;
    width: 0;
    height: 0;
    margin-left: 4px;
    -webkit-transition: opacity 0.2s ease,-webkit-transform 0.2s ease;
    transition: opacity 0.2s ease,-webkit-transform 0.2s ease;
    transition: transform 0.2s ease,opacity 0.2s ease;
    transition: transform 0.2s ease,opacity 0.2s ease,-webkit-transform 0.2s ease;
    -webkit-transform: rotate(0deg);
    transform: rotate(0deg);
    vertical-align: middle;
    border-top: 4px solid;
    border-right: 4px solid transparent;
    border-left: 4px solid transparent;
}
.drawer-dropdown.open .drawer-caret {
    -webkit-transform: rotate(180deg);
    transform: rotate(180deg);
}
.drawer-container {
    margin-right: auto;
    margin-left: auto;
}
@media (min-width:64em) {
    .drawer-container {
        max-width: 60rem;
    }
}
@media (min-width:75em) {
    .drawer-container {
        max-width: 70rem;
    }
}

3.htmlファイル内に記述

「JavaScript」ファイルへのディレクトリをメタタグに記述します。

htmlファイルにJavaScriptの記述
<meta charset="UTF-8">
<title>レスポンシブ・デザインに対応している画像スライダー jQuery「slick」の設定方法|Webデザイナーブログ</title>
<meta name="description" content="左右から表示させるハンバーガーメニューを表示するレスポンシブドロワーメニュー jQuery「drawer.js」のご紹介を致します。">
<meta name="keywords" content="レスポンシブ,ハンバーガーメニュー,drawer.js,drawer,右から出るメニュー,左から出るメニュー,jQuery">
<meta name="robots" content="all">
<meta name="viewport" content="width=device-width, user-scalable=no, initial-scale=1, maximum-scale=1">
<link rel="stylesheet" href="/sample/027/base.css" media="all" />
<link rel="stylesheet" href="/sample/027/drawer.css" />
<!--グローバル-->
<script src="/sample/027/jquery.js"></script>
<script src="/sample/027/iscroll.js"></script>
<script src="/sample/027/drawer.js"></script>
<script>
    $(document).ready(function() {
      $(".drawer").drawer();
    });
</script>

実装サンプル

実装サンプルを作りましたのでこちらでも確認してみてください。
drawer menu Plugin デモ

まとめ

以上で設定完了となりますが、簡単に設定ができますね。
レスポンシブ・デザイン対応の中でも利用者の多いハンバーガーメニューですが、実際作ってみると簡単ですね。 そこまで細かい設定等もありませんし、構造を理解すると意外と簡単です。 ファーストビューで全体をすっきりしたいときにはハンバーガーメニューは使い易いです。