【レスポンシブ対応】CSSのみでの多階層ドロップダウンメニューを作成

最終更新日:2020年08月06日 公開日:2019年2月27日

【お知らせ】[SEO][Chrome拡張機能]検索順位チェックツール登場!

javascript無しでナビゲーションメニューを作る

弊社のホームページはナビゲーションメニューとしてドロップダウンメニューを採用している.
当初は drawer.js を使用して作成されていた.

しかし,CSS だけで実現したいと思い,デザインはそのままにスクリプトを書き替えることにした.
つまり,javascript や jQuery は使わないでスタイルシートのみでパソコン,スマホ両方に対応するメニューを実現した.

なお,実装はシンプルイズベストで,アニメーションはつけていない.
このサンプルコード(ソース)を元に自分で工夫してください.
弊社ホームページは少しアニメーションを取り入れており,サンプルはそのメニューを抜粋した形にしているので,より参考になるはずです.

実現したいこと.

  • スマホとパソコン(PC)で HTML は同一のものを使う
  • javascript は使わずに HTML と CSS だけで動作させる
  • ライブラリは使わないで,可能な限りシンプルに短いスクリプトにする.
  • 多段階の階層メニューに対応(2020/03/24対応)

いろいろ調査してみると,CSSだけでのメニューは実現しているが,スマホ時にハンバーガー形式のメニューに変わるものがなかったり,その逆になっていたりとなかなか見つからなかった.
多階層メニューに関しても横幅が固定のものは見つかったが,横幅が可変のものは現時点でなかなか見つからないようだ.(2020/03/26 追記)
そこで,どなたでも利用できるように作成して,解説付きで公開する.

パソコンでの表示では横並びのメニューにマウスを合わせるとドロップダウンメニューが現れ,スマホでの表示では縦並びのメニューをクリックすると下にメニューが展開されるイメージとなる.

このページではドロップダウンメニュー部分に関して説明をする.
ハンバーガーメニューの解説はリンク先を参照してください.

ドロップダウンでも第二階層が非常に多い場合はメガメニューを使うこともあると思います.
メガメニューの解説はリンク先を参照してください.

サンプルページ
CSSのみでパソコン(PC)時にはドロップダウンメニューで表示され,スマホ(SP)時にはハンバーガーメニューで表示されるメニューを実現する方法
上記リンクを右クリックして,「ファイルを保存」するとソースが保存される.
普通に左クリックすればサンプルページ(デモ画面)を見ることが出来ます.

スタイルシート
nav2.css
こちらも同様にリンクを右クリックして「ファイルを保存」する.

旧バージョンのファイル index.html nav.css 多段が不要な場合はこちらでもOK.

ドロップダウンメニューのポイントの解説

メニューの骨格は箇条書き(ul)で記述

箇条書きにすれば入れ子になったメニューは簡単に表現できる.

HTML は

ハンバーガーメニューに関係するところは削除して,ドロップダウンメニューに関係するところだけ抜粋している.

このバージョンでは,旧バージョンと違って display を使っている.なぜ visibility を使わないかというと多段になった時にマウスの位置が隣のドロップメニューの位置にずれた場合に切り替わってしまうから.

ドロップダウンメニュー部分は初期状態で none にしておき,親メニューの該当場所に上にある (hover) 状態で block に代えることによって表示されるようにしている.
パソコンとスマホの切り替えのブレイクポイントは横幅 620px としているが,変更したい場合はここを変えればよい.

下階層のメニューを左右どちらに出すか

多段にした場合に下に階層がある場合に三角が表示されるようにしている.
サンプルでは三番目のメニューから右は下階層のメニューが左側に表示されるようにしている.(nth-child)
また,#menu li ul li ul li ul は三階層目から下は全て左側に表示されるようにするためである.

少し複雑だが CSS のみで多段階層のメニューを実現した.
現在のところ,IE11 まで対応しているので,ほとんどのブラウザで動作する.
不具合があるようでしたらご連絡ください.

おまけ

ここまでお読みいただきありがとうございました.最後にお知らせです.
皆さまのおかげでこのページは非常にアクセスの多いページとなっております.

このページをご覧になる方は javascript(jQueryなど) を使って作れるメニューを css だけで制作し洗練されたものにしようとされている方のはずです.

デザイナーの方へ

弊社では独自のログ解析を提供し,アクセスアップ,問い合わせアップのアドバイスをしています.実績も十分にあるのですが,HTMLを理解することとは別の思考が必要なので使いこなすのが難しいツールとなっています.そこでデザイナーの方に理解していただき,お客様のホームページの集客に役立てていただくツールとして使っていただけないかと考えています.つまり,一緒に様々な問題を解決して共にスキルアップの出来るパートナー(代理店)を募集しております.ご興味のある方はフォームからその旨ご連絡ください.

自社のホームページを作成している方へ

メニューを洗練されたものにした後はアクセス数アップを目指してみませんか?出版している書籍に方法論は掲載していますが,頭では理解できても実践するのが難しいようです.そのため,弊社では毎月,勉強会も開催しています.よろしければフォームからご相談ください.

参考サイト

CSSだけで作る「多階層」なドロップダウンメニュー
は大変参考になりました.ありがとうございます.
改造のポイントは

  • メニューが固定幅でなくても対応(display を使う)
  • スマホ時のハンバーガーメニューにも対応

の辺りです.

 

Contact

ご質問等ありましたら,下のフォームからお願いします.

 
contact
無料ダウンロード中!
大好評の書籍はこちら
Pagetop