*

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

公開日: : ノウハウ

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

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

スマホサイト

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

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

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

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

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

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

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

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

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

html部分

<header>
<div id="menu-bt">
   <img src="http://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

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

おわりに

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

関連記事

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

上部広告

  • Pocket

おすすめトピックス

関連記事

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

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

MP3ダウンロード
MP3を1クリックだけでストリーミングせずにダウンロードする方法

私はこのサイトとは別に、効果音や BGM の素材サイトを運営しています。ふとそのサイト名で google 検索をしてみた所、驚くべき光景を目にしました。 ポケットサウンドというのがそのサイト名なのですが、Google の […]

プレースホルダ
検索窓に薄い文字を入れて何を入力するのか分かりやすくするプレースホルダ

ネット上で何かを検索したい時、どこを見ますか? そう、検索窓ですよね。検索窓は EC サイトやネットショップ、何かを検索する必要があるウェブサイトには大概付きものでお馴染みのものです。 たまに見るのが検索窓に薄い文字で予 […]

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

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

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

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

スマホを操作する手
スマホでWeb閲覧時代にスマホサイトでNGだと思う事3つ

ちょっと前まではインターネットを見るなら、通販するならパソコン!という時代でしたが、既にこれは終わった時代です。ここ2,3年は、インターネットを閲覧、通販においてもスマートフォン率がだんだん上昇しています。これは当サイト […]

上部広告

著者について

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

フォローはこちら

       

上部広告

       
キャッシュトレイ
三菱東京UFJ銀行でもコンビニATM手数料を無料にする事が可能です(条件有り)

セブンイレブンやローソンなどに設置してあるコンビニ ATM は

サングラス
車を運転中に朝陽が眩しくて信号が見えないのでサングラスで対策した

先日車を運転中にヒヤリとする出来事がありました。それは信号に気が付かな

ニーアオートマタのPC版をGeforce GTX960でプレイした感想

2017年3月18日より発売されたスクエアエニックス(開発はプ

Excelでシートを新規ブックにコピーする方法

Excel で既に出来上がったシートを新しい Excel ファ

アニメーションgifを手軽に圧縮してサイズを落とすウェブツール「Online GIF optimizer」

インターネットの速度がここまで発達して速くなってもアニメーション gi

→もっと見る