【アコーディオンメニュー】プルダウンメニューをスマホ表示でアコーディオン化

PC表示でマウスオーバーで展開するプルダウンメニューを、スマホ表示でアコーディオンメニューにします。htmlとCSSのみで実装し、スマホ表示のみjQueryでtoggleClassを利用します。

htmlのコードは下記になります。リストを入れ子にした構造です。

<ul class="dropmenu">
	<li id="js_cat"><a>カテゴリー</a>
		<ul>
			<li><a href="/category/accordion/">アコーディオンメニュー</a></li>
			<li><a href="/category/calendar/">カレンダー</a></li>
			<li><a href="/category/tab/">タブメニュー</a></li>
			<li><a href="/category/tooltip/">ツールチップ</a></li>
			<li><a href="/category/fade/">フェーダー</a></li>
			<li><a href="/category/form/">フォーム</a></li>
			<li><a href="/category/hover/">マウスオーバー</a></li>
			<li><a href="/category/modal/">モーダルウィンドウ</a></li>
			<li><a href="/category/responsive/">レスポンシブ</a></li>
		</ul>
	</li>
</ul>

続いてCSSのコードです。
カテゴリーのliタグにposition: relativeを設定し、展開メニューのulタグはposition: absoluteを設定してtop: 100%、left: 0の位置に配置します。そして、展開メニューのliタグにoverflow: hidden、height: 0を設定して非表示にします。カテゴリー右側の三角形は、カテゴリーのaタグの疑似要素で作成します。
次にメニュー展開時の処理ですが、今回はメディアクエリでブレイクポイントを600pxに設定し、601px以上でPCの処理、600px以下でスマホの処理を記述しています。PCはカテゴリーのliタグのhover、スマホはカテゴリーのliタグにクラス名active_spを付与することで動作させています。どちらも展開メニューのliタグにoverflow: visible、height: 40pxを設定しています。height: 40pxはfont-size: 14px、padding-top: 13px、padding-bottom: 13pxの合計です。

.dropmenu {
	width: 200px;
	margin: 0 auto;
}
.dropmenu li {
	position: relative;
}
.dropmenu li a {
	display: block;
	margin: 0;
	padding: 13px 15px;
	font-size: 14px;
	line-height: 1;
	background: #444444;
	color: #ffffff;
	cursor: pointer;
}
.dropmenu li a:after {
	content: '';
	display: inline-block;
	position: absolute;
	right: 15px;
	top: 40%;
	width: 0;
	height: 0;
	border-style: solid;
	border-width: 8px 5px 0 5px;
	border-color: #FFFFFF transparent transparent transparent;
}
.dropmenu li ul {
	position: absolute;
	width: 100%;
	z-index: 9999;
	top: 100%;
	left: 0;
}
.dropmenu li ul li{
	overflow: hidden;
	height: 0;
	transition: .2s;
}
.dropmenu li ul li a{
	border-top: 1px solid #dddddd;
	background: #efefef;
	color: #333333;
}
.dropmenu li ul li a:after {
	content: none;
}
.dropmenu li ul li:first-child a{
	border-top: none;
}
@media screen and (min-width: 601px) {
	.dropmenu li:hover a:after {
		transform: rotate(180deg);
		transition: .1s;
	}
	.dropmenu li:hover ul li{
		overflow: visible;
		height: 40px;
	}
	.dropmenu li ul li a:hover {
		background: #ffd999;
		transition: .5s;
	}
}
@media screen and (max-width: 600px) {
	.dropmenu li.active_sp a:after {
		transform: rotate(180deg);
		transition: .1s;
	}
	.dropmenu li.active_sp ul li{
		overflow: visible;
		height: 40px;
	}
}

最後にjQueryのコードです。
ブラウザの横幅480px以下でカテゴリーのliタグにクラス名active_spをtoggleClassしています。

$(function() {
	function sp_menu() {
		var windowWidth = parseInt($(window).width());
		if(windowWidth <= 600) {
			$(this).toggleClass("active_sp");
		}
	}
	$("#js_cat").click(sp_menu);
});
タイトルとURLをコピーしました