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