国产av日韩一区二区三区精品,成人性爱视频在线观看,国产,欧美,日韩,一区,www.成色av久久成人,2222eeee成人天堂

首頁(yè) web前端 js教程 為活動(dòng)狀態(tài)和可擴(kuò)展菜單創(chuàng)建動(dòng)態(tài)導(dǎo)航腳本

為活動(dòng)狀態(tài)和可擴(kuò)展菜單創(chuàng)建動(dòng)態(tài)導(dǎo)航腳本

Nov 08, 2024 am 01:14 AM

Creating a Dynamic Navigation Script for Active State and Expandable Menus

構(gòu)建動(dòng)態(tài) Web 應(yīng)用程序時(shí),用戶界面 (UI) 需要提供直觀的導(dǎo)航體驗(yàn)。無(wú)論是具有多個(gè)產(chǎn)品類別的電子商務(wù)網(wǎng)站還是內(nèi)容豐富的管理儀表板,擁有活動(dòng)狀態(tài)和可擴(kuò)展菜單都可以增強(qiáng)可用性。在這篇博文中,我們將逐步創(chuàng)建一個(gè) JavaScript 腳本,該腳本動(dòng)態(tài)突出顯示導(dǎo)航中的當(dāng)前頁(yè)面,并根據(jù)用戶的路徑展開(kāi)相關(guān)部分。

問(wèn)題

當(dāng)用戶瀏覽多層菜單時(shí),我們希望:

  1. 當(dāng)前頁(yè)面鏈接上的活動(dòng)狀態(tài)
  2. 可擴(kuò)展部分,如果用戶位于嵌套在菜單中的頁(yè)面上,則會(huì)自動(dòng)打開(kāi)。

讓我們看一個(gè)示例 HTML 結(jié)構(gòu)以及如何添加 JavaScript 以使我們的菜單變得智能。

菜單結(jié)構(gòu)示例

這是一個(gè)典型的嵌套菜單結(jié)構(gòu)。我們將為菜單中的每個(gè)項(xiàng)目使用 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. 獲取當(dāng)前路徑
   const currentPath = window.location.pathname;

這會(huì)獲取當(dāng)前頁(yè)面的路徑(例如,/inventory-issues),我們將用它來(lái)與菜單中每個(gè)鏈接的 href 進(jìn)行比較。

  1. 選擇菜單鏈接
   const links = document.querySelectorAll('.menu-link');

我們選擇具有菜單鏈接類的所有元素,假設(shè)這些元素包含指向網(wǎng)站各個(gè)部分的鏈接。

  1. 匹配當(dāng)前頁(yè)面
   if (link.getAttribute('href') === currentPath) {

對(duì)于每個(gè)鏈接,我們檢查其 href 是否與 currentPath 匹配。如果是,則該鏈接適用于當(dāng)前頁(yè)面。

  1. 設(shè)置活動(dòng)狀態(tài)
   menuItem.classList.add('active');

我們向最近的菜單項(xiàng)添加一個(gè)活動(dòng)類,允許我們?cè)O(shè)置活動(dòng)頁(yè)面鏈接的樣式。

  1. 展開(kāi)父菜單
   const parentMenuItem = parentMenu.closest('.menu-item');
   parentMenuItem.classList.add('open');

如果活動(dòng)鏈接位于子菜單 (menu-sub) 內(nèi),這部分代碼將查找包含該子菜單的父菜單項(xiàng)并添加開(kāi)放類,將其展開(kāi)。

為活動(dòng)和開(kāi)放狀態(tài)添加 CSS

您需要為 CSS 中的活動(dòng)類和開(kāi)放類定義樣式:

<!-- 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>

這種方法的好處

  • 自動(dòng)活動(dòng)狀態(tài):無(wú)需在每個(gè)頁(yè)面上對(duì)活動(dòng)鏈接進(jìn)行硬編碼。該腳本動(dòng)態(tài)更新活動(dòng)鏈接。
  • 可擴(kuò)展菜單:用戶只能看到與當(dāng)前頁(yè)面相關(guān)的部分,減少手動(dòng)打開(kāi)菜單的需要。
  • 可重用:該腳本足夠通用,可以與各種嵌套菜單結(jié)構(gòu)一起使用,使其適應(yīng)多種類型的網(wǎng)站。

?來(lái)自埃迪古萊

以上是為活動(dòng)狀態(tài)和可擴(kuò)展菜單創(chuàng)建動(dòng)態(tài)導(dǎo)航腳本的詳細(xì)內(nèi)容。更多信息請(qǐng)關(guān)注PHP中文網(wǎng)其他相關(guān)文章!

本站聲明
本文內(nèi)容由網(wǎng)友自發(fā)貢獻(xiàn),版權(quán)歸原作者所有,本站不承擔(dān)相應(yīng)法律責(zé)任。如您發(fā)現(xiàn)有涉嫌抄襲侵權(quán)的內(nèi)容,請(qǐng)聯(lián)系admin@php.cn

熱AI工具

Undress AI Tool

Undress AI Tool

免費(fèi)脫衣服圖片

Undresser.AI Undress

Undresser.AI Undress

人工智能驅(qū)動(dòng)的應(yīng)用程序,用于創(chuàng)建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

用于從照片中去除衣服的在線人工智能工具。

Clothoff.io

Clothoff.io

AI脫衣機(jī)

Video Face Swap

Video Face Swap

使用我們完全免費(fèi)的人工智能換臉工具輕松在任何視頻中換臉!

熱工具

記事本++7.3.1

記事本++7.3.1

好用且免費(fèi)的代碼編輯器

SublimeText3漢化版

SublimeText3漢化版

中文版,非常好用

禪工作室 13.0.1

禪工作室 13.0.1

功能強(qiáng)大的PHP集成開(kāi)發(fā)環(huán)境

Dreamweaver CS6

Dreamweaver CS6

視覺(jué)化網(wǎng)頁(yè)開(kāi)發(fā)工具

SublimeText3 Mac版

SublimeText3 Mac版

神級(jí)代碼編輯軟件(SublimeText3)

Java vs. JavaScript:清除混亂 Java vs. JavaScript:清除混亂 Jun 20, 2025 am 12:27 AM

Java和JavaScript是不同的編程語(yǔ)言,各自適用于不同的應(yīng)用場(chǎng)景。Java用于大型企業(yè)和移動(dòng)應(yīng)用開(kāi)發(fā),而JavaScript主要用于網(wǎng)頁(yè)開(kāi)發(fā)。

掌握J(rèn)avaScript評(píng)論:綜合指南 掌握J(rèn)avaScript評(píng)論:綜合指南 Jun 14, 2025 am 12:11 AM

評(píng)論arecrucialinjavascriptformaintainingclarityclarityandfosteringCollaboration.1)heelpindebugging,登機(jī),andOnderStandingCodeeVolution.2)使用林格forquickexexplanations andmentmentsmmentsmmentsmments andmmentsfordeffordEffordEffordEffordEffordEffordEffordEffordEddeScriptions.3)bestcractices.3)bestcracticesincracticesinclud

JavaScript評(píng)論:簡(jiǎn)短說(shuō)明 JavaScript評(píng)論:簡(jiǎn)短說(shuō)明 Jun 19, 2025 am 12:40 AM

JavascriptconcommentsenceenceEncorenceEnterential gransimenting,reading and guidingCodeeXecution.1)單inecommentsareusedforquickexplanations.2)多l(xiāng)inecommentsexplaincomplexlogicorprovideDocumentation.3)

如何在JS中與日期和時(shí)間合作? 如何在JS中與日期和時(shí)間合作? Jul 01, 2025 am 01:27 AM

JavaScript中的日期和時(shí)間處理需注意以下幾點(diǎn):1.創(chuàng)建Date對(duì)象有多種方式,推薦使用ISO格式字符串以保證兼容性;2.獲取和設(shè)置時(shí)間信息可用get和set方法,注意月份從0開(kāi)始;3.手動(dòng)格式化日期需拼接字符串,也可使用第三方庫(kù);4.處理時(shí)區(qū)問(wèn)題建議使用支持時(shí)區(qū)的庫(kù),如Luxon。掌握這些要點(diǎn)能有效避免常見(jiàn)錯(cuò)誤。

JavaScript與Java:開(kāi)發(fā)人員的全面比較 JavaScript與Java:開(kāi)發(fā)人員的全面比較 Jun 20, 2025 am 12:21 AM

JavaScriptIspreferredforredforwebdevelverment,而Javaisbetterforlarge-ScalebackendsystystemsandSandAndRoidApps.1)JavascriptexcelcelsincreatingInteractiveWebexperienceswebexperienceswithitswithitsdynamicnnamicnnamicnnamicnnamicnemicnemicnemicnemicnemicnemicnemicnemicnddommanipulation.2)

為什么要將標(biāo)簽放在的底部? 為什么要將標(biāo)簽放在的底部? Jul 02, 2025 am 01:22 AM

PlacingtagsatthebottomofablogpostorwebpageservespracticalpurposesforSEO,userexperience,anddesign.1.IthelpswithSEObyallowingsearchenginestoaccesskeyword-relevanttagswithoutclutteringthemaincontent.2.Itimprovesuserexperiencebykeepingthefocusonthearticl

JavaScript:探索用于高效編碼的數(shù)據(jù)類型 JavaScript:探索用于高效編碼的數(shù)據(jù)類型 Jun 20, 2025 am 12:46 AM

javascripthassevenfundaMentalDatatypes:數(shù)字,弦,布爾值,未定義,null,object和symbol.1)numberSeadUble-eaduble-ecisionFormat,forwidevaluerangesbutbecautious.2)

Java和JavaScript有什么區(qū)別? Java和JavaScript有什么區(qū)別? Jun 17, 2025 am 09:17 AM

Java和JavaScript是不同的編程語(yǔ)言。1.Java是靜態(tài)類型、編譯型語(yǔ)言,適用于企業(yè)應(yīng)用和大型系統(tǒng)。2.JavaScript是動(dòng)態(tài)類型、解釋型語(yǔ)言,主要用于網(wǎng)頁(yè)交互和前端開(kāi)發(fā)。

See all articles