*

プラグイン無しで簡単に実現するスマホサイトの上からドロワーメニューの作り方【jQuery】

公開日: : 最終更新日:2017/11/19 ノウハウ

近年どこでもスマートフォン向けサイトが用意されているのが当たり前です。スマートフォンを使っていればいつも何気なしにスマートフォンサイトを見ていると思います。

そのスマートフォンサイトをちょっと思い出してみてください。

スマホサイト

こんなマークを見たことがありませんか?大抵右上か左上にこの三本線マークがあるのではないかと思います。これはメニューのマークです。このボタンを押す事で画面外の上からか横からメニューが出て来る仕様にしているサイトがほとんどです。このメニューはドロワーメニュー、若しくはハンバーガーメニューと呼ばれています。三本線がハンバーガーみたいだからでしょうね。

その理由はメニューをサイト上に表示してしまうと画面のほとんどを専有してしまいます。元々表示する情報量が少ないスマートフォンですので、メニューは常時表示せずボタンを押す事で表示するようになっています。

この仕様は Google のアプリもその仕様ですし、他社のスマホアプリも追従する形となっておりスマートフォンの世界ではほぼ共通仕様となりつつあります。スマートフォンサイトを個人で作る場合もその仕様に則るのが良いでしょう。しかし三本線「≡」がメニューであるというのはスマートフォンに詳しい人しか認知されていないというのが実情です。≡の下に Menu とラベルを付けておくと親切です。

しかし実際スマートフォンサイトのメニューを作るとなると難しそうでしょう。画面外の上からスムーズにシュッと出てくるのですから色々プログラミングとかしなくてはいけないように思えます。

私も実際に作る機会があったのですが、作り方を調べているとプラグインの導入やら冗長なプログラミングコードを見て半ば嫌になってきました。

しかし、ちょっと仕組みを理解してしまえばスマートフォンサイトの上から出てくるドロワーメニュー、意外と簡単なのです。プラグインを使わなくても自作でいけます。

ここではプラグイン無しで簡単に実現するスマートフォンサイトのシンプルなドロワーメニューの作り方を紹介します。

スマホサイトのドロワーメニューの作り方

まずは html 部分から見てみましょう。

html部分

<header>
<div id="menu-bt">
   <img src="https://webmist.info/image/spmenu.png" id="drower" />
</div>
</header>

<nav id="menu">
<ul>
   <li><a href="#">トップ</a></li>
   <li><a href="#">サイト情報</a></li>
   <li><a href="#">商品情報</a></li>
   <li><a href="#">アクセス</a></li>
</ul>
</nav>

基本はこれだけです。まずメニューボタンと、メニューの項目を ul li タグのリストで構成しています。

次は動きを作る jQuery 部分です。シンプルですのであまり警戒しないでくださいね。

jQuery部分

<script src="//ajax.googleapis.com/ajax/libs/jquery/1.8.2/jquery.min.js"></script>
<script>
$(function(){
   $("#menu").css("display","none");
   $("#menu-bt").on("click", function() {
      $("#menu").slideToggle(300);
      $(this).toggleClass("active");
   });
});
</script>

jQuery 部分も基本はこれだけです。意外とシンプルだったでしょう。

まずは jQuery 本体をスクリプトタグで読み込みます。

1行目から順番に解説すると、menu という id を指定している部分、すなわちメニュー部分を最初は非表示にしています。次に menu-bt という id を指定している部分(メニューボタン)をクリックするとどうなるかを書いているのが2行目以降です。

そして、メニュー部分に対して slideToggle という関数を呼び出しています。これはスライドさせて表示せよという命令です。カッコ内は何秒でメニューを表示するかという指定です。これはミリ秒で指定します。1秒なら1000です。

最後に menu という id を指定しているメニュー部分に active というクラスを追加しています。これはメニューが開いている状態というのが区別できるようにする為です。

実はここまででドロワーメニューの基本は動作します。下記サンプルをご覧ください。

ドロワーメニューのDEMO1

これだけでも ul li タグのリストがメニューとして上からスライドしてきていますね。しかし、まだ貧相です。ここから CSS でデザインを付けていきます。

CSS部分

nav#menu{
   width:100%;	
}
	
nav#menu ul{
   margin:0px;
   padding:0px;	
}
	
nav#menu ul li{
   list-style-type:none;	
}
	
nav#menu ul li a{
   width:100%;
   display:block;
   background-color:#333;
   color:#fff;
   border-bottom:1px solid #ccc;	
   text-align:center;
   padding:9px 0px 9px 0px;
}

一例ですが、CSS でデザインを付けてみました。CSS が一番長かったですね。デザインを付けたら下記のようになりました。

ドロワーメニューのDEMO2

ここまででもう完成に近い状態になりました。しかしよく見てください。このままでは、メニューをどうやって閉じたら良いかわからない人が出てきそうです。

よく使われる手法としては、メニューを開いたら≡マークを×に変化させる事で閉じる事を示す方法が多いです。×マークで閉じるは Windows でもお馴染みの習わしですからね。

メニューマークを×ボタンに変化させてみましょう。ここではシンプルに×マークの画像を用意して画像だけを変更します。

メニューボタンを閉じるボタンに切り替える

先程の jQuery コードに少し追記します。

<script src="//ajax.googleapis.com/ajax/libs/jquery/1.8.2/jquery.min.js"></script>
<script>
$(function(){
   $("#menu").css("display","none");
   $("#menu-bt").on("click", function() {
      $("#menu").slideToggle(300);
      $(this).toggleClass("active");
      if($(this).hasClass("active")){
         $("#drower").attr('src','閉じるボタンURL');
      }else{
         $("#drower").attr('src','メニューボタンURL');
      }
   });
});
</script>

追記したのは「if($(this).hasClass(“active”)){」以降です。

active というクラスが付いていたら、すなわちメニューが開いていたら drower という id が指定してある img タグの src 属性を閉じるボタンの画像 URL に変更するという処理です。逆にメニューが閉じていたらメニューボタンに切り替えます。

この処理を加えると下記のようになります。

ドロワーメニューのDEMO3

これでメニューボタンが閉じるボタンに切り替わるようになりました。

おわりに

スマホサイトのドロワーメニューを作るのは難しそうと思っていましたが、蓋を開けてみたら意外と簡単でした。今回は一番シンプルなドロワーメニューの作り方を紹介しましたが、二段階で展開するメニューや横からスライドするメニューを作りたい場合は、自作だとかなり難しくなってしまうので別途プラグインを導入する必要があります。

関連記事

ローディング画面の作り方

cssとjqueryでサイトのローディング画面を簡単に実現する作り方【プラグインなし】
現在ロード中を知らせるローディング画面(Now Loading)は今までにどこかのサイトで見たことがあるかと思います。かつて FLASH 動画全盛の時代にはこんなローディン

スマホサイトのフッターの作り方

これを見れば簡単!スマホサイトのフッターメニューをサクッと作るサンプル
スマートフォンなどのモバイル端末でウェブサイトを見る人が急増し、今の時代スマートフォン用サイトを作る事が当たり前となりました。スマホ用に別の html ファイルを用意するより一つの

  • Pocket

おすすめトピックス

関連記事

これを見れば簡単!スマホサイトのフッターメニューをサクッと作るサンプル

スマートフォンなどのモバイル端末でウェブサイトを見る人が急増し、今の時代スマートフォン用サイトを作る事が当たり前となりました。スマホ用に別の html ファイルを用意するより一つの html で両方に対応するレスポンシブ […]

css3
CSS3で要素の2番目以降、1番目以外にスタイルを適用する擬似クラス

スタイルシート(CSS)はウェブサイトにデザインを適用するための言語。そのスタイルシートのバージョンは今では3になっており、かなり表現力豊かで優秀になっています。 例えば ul li タグのリストの場合、従来の CSS2 […]

動く炭酸
飲み物の写真がリアルに動き出す!フリーソフトSizzTassの使い方

知り合いに聞いたのですが、「料理の写真からぐつぐつと煮えたぎる写真を作れるソフトがあるらしいよ。テレビでやってた。」と。最初は何だそれは?と思って意味がよく理解できませんでした。 ソフト名を聞いて調べてみたのですが、確か […]

画像付きリスト
関連記事などに画像付きリストをCSSで簡単に作るサンプル

画像つきリストとは上図のようなイメージです。しばしばブログなどでは関連記事や人気記事の表示などに使われている事が多いですし、インターネットショッピングサイトではサイドメニューの商品カテゴリリストに採用されています。 ポイ […]

CSSの擬似クラスnth-childは3の倍数以外というような否定条件も可能

CSS において偶数の要素だけ、奇数の要素だけ、何番目の要素だけというような細かな指定ができる擬似クラスがあります。 例えばリストの3番目の要素なら次のように指定します。 偶数番目の要素だけ指定したいなら… 奇数番目の要 […]

リファラーによってiframe内のリンク先をjavascriptで変更する

リファラーによってインラインフレーム内にあるリンクのリンク先を変えれたら便利になるなと思って javascript で自作してみました。こんな事したいと思う人は多分いないニッチなものだと思います。 どういう時に使いたかっ […]

著者について

名前:Azell
作曲したり風景写真撮ったりWeb制作したりする人です。 好きな事を楽しくブログに綴れていけたらと思います。

フォローはこちら

       

       
エックスサーバーでメールが送れない「Client host rejected:Access denied」

エックスサーバーで作成したメールアカウントでメールを送信しよう

札幌駅パセオ地下1階のパスタとパフェが美味しい「プロヴァンス」でランチ

札幌駅のパセオ地下1階にあるプロヴァンスは南フランスとイタリア

千歳市の和食処「ほうりん」の安い充実の寿司ランチ

千歳市にある和食処ほうりんは千歳駅の南西にある居酒屋が立ち並ぶ

スパホテルソーレ
札幌のカプセルホテル「スパホテルソーレすすきの」に泊まった感想

札幌の地下鉄すすきの駅の近くにあるカプセルホテル「スパホテルソ

札幌駅近くのモダン和食レストラン「えりも亭」で珍しい縮れ蕎麦ランチ

札幌駅の北口から徒歩2分程度の所に和風なモダンレストラン「えり

→もっと見る