ホームページ > ウェブフロントエンド > jsチュートリアル > アクティブ状態および展開可能なメニュー用の動的ナビゲーション スクリプトの作成

アクティブ状態および展開可能なメニュー用の動的ナビゲーション スクリプトの作成

Linda Hamilton
リリース: 2024-11-08 01:14:03
オリジナル
344 人が閲覧しました

Creating a Dynamic Navigation Script for Active State and Expandable Menus

動的 Web アプリケーションを構築する場合、ユーザー インターフェイス (UI) は直感的なナビゲーション エクスペリエンスを提供する必要があります。複数の製品カテゴリを含む電子商取引サイトであっても、コンテンツの多い管理ダッシュボードであっても、アクティブな状態と展開可能なメニューがあると使いやすさが向上します。このブログ投稿では、ナビゲーション内の現在のページを動的に強調表示し、ユーザーのパスに基づいて関連セクションを展開する JavaScript スクリプトの作成について説明します。

問題

ユーザーが多層メニューをナビゲートするとき、次のことが必要です。

  1. 現在のページのリンクの アクティブ状態
  2. 展開可能なセクション。ユーザーがメニュー内にネストされたページにいる場合に自動的に開きます。

HTML 構造の例と、JavaScript を追加してメニューをスマートにする方法を見てみましょう。

メニュー構造例

これは典型的なネストされたメニュー構造です。メニュー内の各項目には menu-item、リンクには menu-link、折りたたみ可能なサブメニューには menu-sub を使用して作業します。

<!-- Categories -->
<li>



<p>In this structure:</p>

<ul>
<li>Each main menu link (menu-toggle) opens a submenu when clicked.</li>
<li>The actual pages are in the submenu links (menu-link).</li>
</ul>

<h3>
  
  
  The JavaScript Solution
</h3>

<p>We’ll use JavaScript to:</p>

<ol>
<li>Identify the current page.</li>
<li>Apply an active class to the link that matches the current URL.</li>
<li>Add an open class to the parent menu if the link is inside a collapsed submenu.</li>
</ol>

<p>Here’s the JavaScript code:<br>
</p>

<pre class="brush:php;toolbar:false"><script>
    window.onload = function () {
        const currentPath = window.location.pathname; // Get the current path
        const links = document.querySelectorAll('.menu-link'); // Select all menu links

        links.forEach(function (link) {
            // Check if the link's href matches the current page's path
            if (link.getAttribute('href') === currentPath) {
                // Add 'active' class to the parent 'li' element of the link
                const menuItem = link.closest('.menu-item');
                if (menuItem) {
                    menuItem.classList.add('active');

                    // Check if the link is within a 'menu-sub', expand the parent menu
                    const parentMenu = menuItem.closest('.menu-sub');
                    if (parentMenu) {
                        // Add 'open' class to the parent 'menu-item' of the submenu
                        const parentMenuItem = parentMenu.closest('.menu-item');
                        if (parentMenuItem) {
                            parentMenuItem.classList.add('open');
                        }
                    }
                }
            }
        });
    };
</script>
ログイン後にコピー
ログイン後にコピー

コードを分解する

  1. 現在のパスを取得:
   const currentPath = window.location.pathname;
ログイン後にコピー

これにより、現在のページのパス (/inventory-issues など) が取得されます。これを使用して、メニュー内の各リンクの href と比較します。

  1. メニューリンクを選択:
   const links = document.querySelectorAll('.menu-link');
ログイン後にコピー

クラスのメニューリンクを持つすべての要素を選択します。これらの要素にはサイトのさまざまなセクションへのリンクが含まれていると仮定します。

  1. 現在のページと一致します:
   if (link.getAttribute('href') === currentPath) {
ログイン後にコピー

リンクごとに、その href が currentPath と一致するかどうかを確認します。存在する場合、そのリンクは現在のページに対するものです。

  1. アクティブ状態の設定:
   menuItem.classList.add('active');
ログイン後にコピー

アクティブなクラスを最も近いメニュー項目に追加し、アクティブなページのリンクのスタイルを設定できるようにします。

  1. 親メニューの展開:
   const parentMenuItem = parentMenu.closest('.menu-item');
   parentMenuItem.classList.add('open');
ログイン後にコピー

アクティブなリンクがサブメニュー (menu-sub) 内にある場合、コードのこの部分はそのサブメニューを含む親メニュー項目を検索し、オープン クラスを追加して展開します。

アクティブ状態とオープン状態の CSS の追加

CSS でアクティブなクラスと開いているクラスのスタイルを定義する必要があります。

<!-- Categories -->
<li>



<p>In this structure:</p>

<ul>
<li>Each main menu link (menu-toggle) opens a submenu when clicked.</li>
<li>The actual pages are in the submenu links (menu-link).</li>
</ul>

<h3>
  
  
  The JavaScript Solution
</h3>

<p>We’ll use JavaScript to:</p>

<ol>
<li>Identify the current page.</li>
<li>Apply an active class to the link that matches the current URL.</li>
<li>Add an open class to the parent menu if the link is inside a collapsed submenu.</li>
</ol>

<p>Here’s the JavaScript code:<br>
</p>

<pre class="brush:php;toolbar:false"><script>
    window.onload = function () {
        const currentPath = window.location.pathname; // Get the current path
        const links = document.querySelectorAll('.menu-link'); // Select all menu links

        links.forEach(function (link) {
            // Check if the link's href matches the current page's path
            if (link.getAttribute('href') === currentPath) {
                // Add 'active' class to the parent 'li' element of the link
                const menuItem = link.closest('.menu-item');
                if (menuItem) {
                    menuItem.classList.add('active');

                    // Check if the link is within a 'menu-sub', expand the parent menu
                    const parentMenu = menuItem.closest('.menu-sub');
                    if (parentMenu) {
                        // Add 'open' class to the parent 'menu-item' of the submenu
                        const parentMenuItem = parentMenu.closest('.menu-item');
                        if (parentMenuItem) {
                            parentMenuItem.classList.add('open');
                        }
                    }
                }
            }
        });
    };
</script>
ログイン後にコピー
ログイン後にコピー

このアプローチの利点

  • 自動アクティブ状態: すべてのページでアクティブ リンクをハードコーディングする必要はありません。このスクリプトはアクティブなリンクを動的に更新します。
  • 展開可能なメニュー: ユーザーには現在のページに関連するセクションのみが表示され、手動でメニューを開く必要が減ります。
  • 再利用可能: このスクリプトは、さまざまなネストされたメニュー構造で動作するのに十分な汎用性を備えているため、複数のタイプのサイトに適応できます。

?エディギュレーより

以上がアクティブ状態および展開可能なメニュー用の動的ナビゲーション スクリプトの作成の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

ソース:dev.to
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
著者別の最新記事
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート