[JS]余分なHTMLは加えずに、セマンティックに実装するスマートフォン用のナビゲーション
Post on:2012年4月6日
デスクトップ時はアイテムが水平に並び、スマートフォン時は省スペースのドロップダウン型に変わるナビゲーションを実装するチュートリアルを紹介します。

Mobile Navigation Design & Tutorial
[ad#ad-2]
デモ
デモは600pxを境にナビゲーションが変わります。

デモページ:幅1200pxで表示

デモページ:幅480pxで表示
[ad#ad-2]
アイテムの2番目がドロップダウン対応になっています。

デモページ:幅1200pxで表示
ドロップダウンの箇所は、スマートフォン時にインデントになります。

デモページ:幅480pxで表示
実装
HTML
HTMLは非常にシンプルで、リスト要素を使いnav要素で内包するだけです。
<nav id="nav-wrap"> <ul id="nav"> <li><a href="#">Button</a></li> <li><a href="#">Button</a></li> </ul> </nav>
JavaScript
スクリプトではスマートフォン用にdiv要素で「Menu」を加え、それがクリックされるとアニメーションでスライドします。
<script type="text/javascript" src="http://ajax.googleapis.com/ajax/libs/jquery/1.7/jquery.min.js"></script> <script type="text/javascript"> jQuery(document).ready(function($){ /* prepend menu icon */ $('#nav-wrap').prepend('<div id="menu-icon">Menu</div>'); /* toggle nav */ $("#menu-icon").on("click", function(){ $("#nav").slideToggle(); $(this).toggleClass("active"); }); }); </script>
HTMLは下記のような状態になります。
<nav id="nav-wrap"> <div id="menu-icon">Menu</div> <ul id="nav"> <li><a href="#">Button</a></li> <li><a href="#">Button</a></li> </ul> </nav>
CSS:ナビゲーションのデスクトップ用スタイル
デスクトップ時には「Menu」は「display: none;」で非表示にします。
#nav-wrap { margin-top: 20px; } /* menu icon */ #menu-icon { display: none; /* hide menu icon initially */ } #nav, #nav li { margin: 0; padding: 0; } #nav li { list-style: none; float: left; margin-right: 5px; } /* nav link */ #nav a { padding: 4px 15px; display: block; color: #000; background: #ecebeb; } #nav a:hover { background: #f8f8f8; } /* nav dropdown */ #nav ul { background: #fff; padding: 2px; position: absolute; border: solid 1px #ccc; display: none; /* hide dropdown */ width: 200px; } #nav ul li { float: none; margin: 0; padding: 0; } #nav li:hover > ul { display: block; /* show dropdown on hover */ }
CSS:ナビゲーションのスマートフォン用スタイル
スマートフォン時には「Menu」を「display: block;」で表示します。
@media screen and (max-width: 600px) { /* nav-wrap */ #nav-wrap { position: relative; } /* menu icon */ #menu-icon { color: #000; width: 42px; height: 30px; background: #ecebeb url(images/menu-icon.png) no-repeat 10px center; padding: 8px 10px 0 42px; cursor: pointer; border: solid 1px #666; display: block; /* show menu icon */ } #menu-icon:hover { background-color: #f8f8f8; } #menu-icon.active { background-color: #bbb; } /* main nav */ #nav { clear: both; position: absolute; top: 38px; width: 160px; z-index: 10000; padding: 5px; background: #f8f8f8; border: solid 1px #999; display: none; /* visibility will be toggled with jquery */ } #nav li { clear: both; float: none; margin: 5px 0 5px 10px; } #nav a, #nav ul a { font: inherit; background: none; display: inline; padding: 0; color: #666; border: none; } #nav a:hover, #nav ul a:hover { background: none; color: #000; } /* dropdown */ #nav ul { width: auto; position: static; display: block; border: none; background: inherit; } #nav ul li { margin: 3px 0 3px 15px; } }
デモはデスクトップとスマートフォンで下記のように変わります。

sponsors