0%

Programmingプログラミングナレッジ

Posted:2018.01.25

jQueryで多階層のナビゲーションメニューを実装する

今更感もありますが、まだまだクライアントワークで求められることも多いので備忘録をして残しておきたいと思います。タイトルの通りグローバルナビなどでメニューが多階層になった形のものを実装します。

 

特徴としてはリスト内で親子関係があったりと入れ子になっている状態になっています。項目をクリックしたりマウスカーソルを重ねると、その子要素に当たるリストが表示といった感じです。最近ではダッシュボードのメニューなどでもよく見かけます。

 

コードですが、まずはHTMLから見ていきます。今回はわかりやすいようにリスト要素を使用しています。li要素の中に子要素にあたるulを入れてネストの状態になっています。CSSは適宜スタイルに合わせて調整しますが、子要素と孫要素にあたるリストは非表示にしておきます。

【html】※一部抜粋

<ul class="parent">
  <li>Menu 01
  </li>
  <li>Menu 02
    <ul class="child">
      <li>Menu 02-01
      </li>
      <li>Menu 02-02
        <ul class="grandchild">
          <li>Menu 02-02-01
          </li>
          <li>Menu 02-02-02
          </li>
          <li>Menu 02-02-03
          </li>
        </ul>
      </li>
      <li>Menu 02-03
      </li>
    </ul>
  </li>
  <li>Menu 03
  </li>
</ul>

 

 

次にjQueryで動きをつけていきます。下記のコードはhoverのイベントで設定しています。実装自体は非常にシンプルで、hoverになっているli要素の子要素に当たるul要素を表示させている形になります。表示非表示にはslideDownやshowなどエフェクトに合わせた表示方法を採用するといいかと思います。階層が深くなっても同じ形で流用できるかと思います。

【javascript】

$(function(){
  var parentList = $(".parent");
  var parentListTrig = $(".parent > li");
  var childList = $(".child");
  var childListTrig = $(".child > li");
  parentListTrig.hover(function(){
    $(this).children('.child').slideDown('fast');
  }, function() {
    $(this).children('.child').slideUp('fast');
  });
  childListTrig.hover(function(){
    $(this).children('.grandchild').show('fast');
  }, function() {
    $(this).children('.grandchild').hide('fast');
  });
});

 

いかがでしょうか、サイトによってページや画面数が多いなどのケースでは表示方法に悩むケースもあるかと思いますがそのような場合に使えるかと思います。今回のサンプルはこちらに用意しておりますのでご参考に。

author
この記事を書いた人オガワ シンヤ
FacebookTwitter

DesignSupply.代表 / ディレクター・ウェブデザイナー・フロントエンドエンジニアをやっています。「ウェブとデザインでヒト・モノ・サービスを繋げ新しい価値を生み出す」をコンセプトに日々奮闘中!制作中はチョコレートが欠かせない三十路Webクリエイター。

制作のご依頼やお問い合わせ・パートナー業務提携のご相談はこちら

デザインやウェブ制作についてのご依頼やご相談、その他お問い合わせなどもお気軽にご連絡ください。フットワークの軽さやレスポンスの早さ、また豊富な経験や知識、技術を活かした対応力といったフリーランスクリエイターの強みでクライアント様、パートナー企業様のお力になります。デザインからコーディングやWordPress実装といったウェブサイト構築はもちろん、写真撮影や動画編集、コンテンツ制作からサイト運用サポートまで一括してお任せください。

ホームページ制作のご検討やウェブ運用でお悩みの経営者様や企業のウェブ担当者様をはじめ、個人で店舗を営んでいらっしゃるオーナー様、フリーで活動されているビジネスオーナー様はもちろんのこと、リソース不足でお困りの制作会社様、またクリエイターをお探しの代理店様も大歓迎です。

コンタクトをご希望の方はお手数ですが、下記よりお問い合わせフォームのページへアクセスしていただき、必要事項を入力の上メッセージを送信してください。確認でき次第すぐに折り返しご連絡致します。

こんな記事も読まれています

コメントもお気軽にどうぞ

記事に関するご質問やご意見などありましたら下記のコメントフォームよりお気軽に投稿ください。なおメールアドレスは公開されませんのでご安心ください。また、* が付いている欄は必須項目となります。

内容に問題なければ、下記の「コメントを送信する」ボタンを押してください。

CAPTCHA


ページトップへ
大阪市天王寺区のホームページ制作デザイン事務所(SOHO)DesignSupply.【デザインサプライ】