Webサイト制作

投稿日:2017年8月29日 更新日:

cssだけでドロップダウンメニューを実装(軽い!)

ドロップダウンメニューをcssだけで実装できる方法があるらしい。
jsファイルの読み込みがないなら軽くていいなぁと思いやってみた。

まずはhtml

一般的な入れ子構造のリストです。


<header>


		<ul>
        	<li><a href="">menu01</a>
            	<ul>
                	<li><a href="">menu01-01</a></li>
                    <li><a href="">menu01-02</a></li>
                    <li><a href="">menu01-03</a></li>
                    <li><a href="">menu01-04</a></li>
                    <li><a href="">menu01-05</a></li>
                </ul>
            </li>
            <li><a href="">menu02</a>
            	<ul>
                	<li><a href="">menu02-01</a></li>
                    <li><a href="">menu02-02</a></li>
                    <li><a href="">menu02-03</a></li>
                    <li><a href="">menu02-04</a></li>
                    <li><a href="">menu02-05</a></li>
                </ul>
            </li>
            <li><a href="">menu03</a></li>
            <li><a href="">menu04</a></li>
		</ul>


</header>

つぎにcss

先ほどのhtmlにcssを追加していきます。
まずは全てのcss。


header > ul{
	display: -webkit-flex;display: flex;
	-webkit-flex-wrap: wrap;flex-wrap: wrap;
	box-sizing:border-box;
	-webkit-justify-content: space-between;
    justify-content: space-between;
	width:80%;margin:30px auto;
	}

header > ul > li{
	-webkit-flex-grow:1;flex-grow:1;
	margin:0 1px;position: relative;
	}
header > ul > li a{
	display:block;
	padding:10px 20px;background:#fff;
	}
header > ul > li a:hover{background:#fff;}

header > ul > li > ul{
	display: -webkit-flex;display: flex;
	-webkit-flex-direction: column;flex-direction: column;
	position: absolute;}

header  > ul > li:hover > ul{
	z-index:3;
	width:100%;margin:0 auto;
	}

header > ul > li > ul > li{
	overflow: hidden;
	height: 0;
	transition: .2s;}
header  > ul > li:hover > ul li{
	overflow: visible;
	height: 38px;
	border-bottom:1px solid #ccc;
	}
header  > ul > li:hover > ul li:first-child{
	border-top:1px solid #ccc;
	}

header > ul > li > ul > li a{background:#ededed;}

cssの中身の解説

順に説明していきます。
まずは通常表示するメニューを横並びにするべく、親ulに対してdisplay:flex;の記述。
全体の横幅を80%にしmarginの設定もしました。

次に、親ulのliに対してposition:relative;を指定しておき、コンテンツサイズに応じて伸縮するようflex-growを指定しました。


header > ul{
	display: -webkit-flex;display: flex;
	-webkit-flex-wrap: wrap;flex-wrap: wrap;
	box-sizing:border-box;
	-webkit-justify-content: space-between;
    justify-content: space-between;
	width:80%;margin:30px auto;
	}

header > ul > li{
	-webkit-flex-grow:1;flex-grow:1;
	margin:0 1px;position: relative;
	}

li aにはdisplay:block;と必要な余白、backgroundの色を設定します。
ついでにhover時の色も。


header > ul > li a{
	display:block;
	padding:10px 20px;background:#fff;
	}
header > ul > li a:hover{background:#fff;}

そして次は子ulへの指定です。
display:flex;
こちらは縦に並んで欲しいのでflex-direction: column;を指定し、position:absolute;します。

そしてhoverで表示させる時にwidth:100%;とz-index。
横幅を100%にすると端が揃います。

header > ul > li > ul{
	display: -webkit-flex;display: flex;
	-webkit-flex-direction: column;flex-direction: column;
	position: absolute;}

header  > ul > li:hover > ul{
	z-index:3;
	width:100%;margin:0 auto;
	}
あとは、以下の記述。
通常height:0;で見えないようにしてhoverで表示された時に子ul の liに対して高さを指定します。

header > ul > li > ul > li{
	overflow: hidden;
	height: 0;
	transition: .2s;}
header  > ul > li:hover > ul li{
	overflow: visible;
	height: 38px;
	border-bottom:1px solid #ccc;
	}
header  > ul > li:hover > ul li:first-child{
	border-top:1px solid #ccc;
	}

高さや背景はお好みで

borderやheight,backgroundはお好きな色で。
floatではなくflexを使うことで少しcssの記述も少なくなりました。
次回制作時、忘れないようにメモ。

これを作るにあたってこちらのページを参考にしました。
ありがとうございます。

■ここはドロップダウンメニューがおりてくる際の動きにバリエーションがあるので色々試してみたい人にはおすすめです。
web park:CSSで作ったドロップダウンメニューのドロップの動きいろいろ

■基本的な構造を理解するのに参考になりました。
マウスオーバーで簡単CSSプルダウン(ドロップダウン)メニュー

- Webサイト制作
-

関連記事

IE10で要素がはみ出してしまう時の対処法

なぜかIEだけ特定の要素がはみ出てしまうことはありませんか?私はよくあります。 ページ作成をしていてブラウザチェックをしているとよくぶち当たるこの問題。 何度か解決してるけど、しばらくしたら忘れてしま ...

no image

画像の拡大表示(ポップアップ)

目次1 やりたいこと2 タグを設置3 画像にクラスを付与4 スクリプトを記載5 スタイルを記載6 完成! やりたいこと 画像のポップアップがしたい! タグを設置 html内であればどこでも良いので、ポ ...

cssだけで画像をテキストの形に切り抜き表示してみる

面白かったのでメモ。 テキストの形に切り抜くやつです。 どこかで使えそう。 目次1 まずはhtml2 cssを追加します。3 テキストの背景指定も まずはhtml 何でもいいので適当なクラスか何かあた ...

webサイト制作時に役立つ!メインカラーを元にカラーを選べるサイト

web制作する時にカラーの組み合わせを調べたい時、色々なジェネレーターはあるけど たとえば メインカラーがすでに決まっていて それに合うカラーが知りたい時 ってないですか?私は結構あります。で、ジェネ ...

no image

Video要素の縦横比を変更する

目次1 やりたいこと2 原因3 対策3.1 対策13.2 対策23.3 問題点 やりたいこと Videoファイルが横長で見にくいので縦幅を調整したい 原因 Video要素のobject-fitがデフォ ...