2. ソースのまとめ(3段階以降のドロップダウンメニュー)
3段階以降のドロップダウンメニューを作るHTML+CSSソースをまとめて掲載しておきます。コピー&ペーストして使ってみて下さい。■HTMLソース:
<ul class="ddmenu">
<li><a href="#">HOME</a></li>
<li><a href="#">ニュース</a>
<ul>
<li><a href="#">新製品 »</a>
<ul>
<li><a href="#">ハードウェア</a></li>
<li><a href="#">ソフトウェア</a></li>
</ul>
</li></li>
<li><a href="#">新サービス</a></li>
<li><a href="#">弊社について</a></li>
</ul>
</li>
<li><a href="#">製品・技術</a>
<ul>
<li><a href="#">ハードウェア »</a>
<ul>
<li><a href="#">法人向け</a></li>
<li><a href="#">個人向け</a></li>
</ul>
</li>
<li><a href="#">ソフトウェア »</a>
<ul>
<li><a href="#">for Windows</a></li>
<li><a href="#">for Mac</a></li>
<li><a href="#">for Android</a></li>
<li><a href="#">for iOS</a></li>
<li><a href="#">その他</a></li>
</ul>
</li>
<li><a href="#">ウェブサービス</a></li>
</ul>
</li>
<li><a href="#">会社情報</a>
<ul>
<li><a href="#">会社概要 »</a>
<ul>
<li><a href="#">グループ概要</a></li>
<li><a href="#">本社概要</a></li>
</ul>
</li>
<li><a href="#">社長挨拶</a></li>
<li><a href="#">沿革</a></li>
<li><a href="#">所在地 »</a>
<ul>
<li><a href="#">本社</a></li>
<li><a href="#">支社</a></li>
</ul>
</li>
</ul>
</li>
<li><a href="#">お問い合わせ</a>
<ul class="sub">
<li><a href="#">よくあるご質問 »</a>
<ul>
<li><a href="#">サービスに関して</a></li>
<li><a href="#">弊社に関して</a></li>
<li><a href="#">その他</a></li>
</ul>
</li>
<li>
<a href="#">お問い合わせ先 »</a>
<ul>
<li><a href="#">大阪本社</a></li>
<li><a href="#">支社 »</a>
<ul>
<li><a href="#">神戸支社</a></li>
<li><a href="#">京都営業所</a></li>
<li><a href="#">奈良営業所</a></li>
</ul>
</li>
</ul>
</li>
</ul>
</li>
</ul>
■CSSソース:
/* -------------------- */
/* ▼メニューバーの装飾 */
/* -------------------- */
ul.ddmenu {
margin: 0px; /* メニューバー外側の余白(ゼロ) */
padding: 0px 0px 0px 15px; /* メニューバー内側の余白(左に15px) */
background-color: #cc0000; /* バーの背景色(濃い赤色) */
}
/* -------------------------- */
/* ▼メインメニュー項目の装飾 */
/* -------------------------- */
ul.ddmenu li {
width: 125px; /* メニュー項目の横幅(125px) */
display: inline-block; /* ★横並びに配置する */
list-style-type: none; /* ★リストの先頭記号を消す */
position: relative; /* ★サブメニュー表示の基準位置にする */
}
ul.ddmenu a {
background-color: #cc0000; /* メニュー項目の背景色(濃い赤色) */
color: white; /* メニュー項目の文字色(白色) */
line-height: 40px; /* メニュー項目のリンクの高さ(40px) */
text-align: center; /* メインメニューの文字列の配置(中央寄せ) */
text-decoration: none; /* メニュー項目の装飾(下線を消す) */
font-weight: bold; /* 太字にする */
display: block; /* ★項目内全域をリンク可能にする */
}
ul.ddmenu a:hover {
background-color: #ffdddd; /* メニュー項目にマウスが載ったときの背景色(淡いピンク) */
color: #dd0000; /* メニュー項目にマウスが載ったときの文字色(濃い赤色) */
}
/* ---------------------------------- */
/* ▼サブメニューがある場合に開く処理 */ /* ※サブメニューが2階層以上ある場合の記述 */
/* ---------------------------------- */
ul.ddmenu li:hover > ul {
display: block; /* ★マウスポインタが載っている項目の内部にあるリストを表示する */
}
/* -------------------- */
/* ▼サブメニューの装飾 */
/* -------------------- */
ul.ddmenu ul {
margin: 0px; /* ★サブメニュー外側の余白(ゼロ) */
padding: 0px; /* ★サブメニュー内側の余白(ゼロ) */
display: none; /* ★標準では非表示にする */
position: absolute; /* ★絶対配置にする */
}
/* -------------------------------- */
/* ▼サブメニュー(以降の)項目の装飾 */
/* -------------------------------- */
ul.ddmenu ul li {
width: 135px; /* サブメニュー1項目の横幅(135px) */
border-top: 1px solid pink; /* 項目上側の枠線(ピンク色で1pxの実線) */
}
ul.ddmenu ul li a {
line-height: 35px; /* サブメニュー1項目の高さ(35px) */
text-align: left; /* 文字列の配置(左寄せ) */
padding-left: 5px; /* 文字列前方の余白(5px) */
font-weight: normal; /* 太字にはしない */
}
ul.ddmenu ul li a:hover {
background-color: #ffff80; /* サブメニュー項目にマウスが載ったときの背景色(淡い黄色) */
color: #005500; /* サブメニュー項目にマウスが載ったときの文字色(濃い緑色) */
}
/* ----------------------------------- */
/* ▼3階層目以降(孫メニュー以降)の装飾 */ /* ※下ではなく横(右)に表示します。 */
/* ----------------------------------- */
ul.ddmenu ul ul {
margin: 0px; /* ★サブメニュー外側の余白(ゼロ) */
padding: 0px; /* ★サブメニュー内側の余白(ゼロ) */
display: none; /* ★標準では非表示にする */
position: absolute; /* ★絶対配置にする */
top: -1px; /* 1pxだけ上方向にずらす(※上に1pxの枠線を引いている場合) */
left: 100%; /* ★基準位置からの距離を親ボックスの幅100%にする */
border-left: 1px solid pink; /* 左側に引く枠線(ピンク色で1pxの実線) */
}
CSSソース内の「★」部分は必ず記述する必要があります。それ以外の装飾は自由に調整して下さい。■表示例:
ここまでのソースを表示すると下図のように見えます。スクリプトを使うことなく複数階層のドロップダウンメニューが機能しています。
3段階以上でも動作するドロップダウンメニューが完成
実際にお使いのブラウザで表示と動作を確認したい場合は、サンプルページ「3段以上のドロップダウンメニューのサンプルページ」をご覧下さい。
ドロップダウンメニューはJavaScript不要のHTML+CSSで作成可能
今回は、スクリプトを使うことなくHTML+CSSだけでシンプルなドロップダウンメニューを作る方法をご紹介いたしました。閲覧者のマウス操作に応じてサブメニューを開閉するような仕組みでも、特にJavaScriptを使わずに実現可能なことがお分かり頂けたでしょう。何段でも好きなだけ深いメニューが作れます。ぜひ試してみて下さい。【関連記事】







