javascript - 我做了一个 Accordion 菜单,但没有子菜单的链接不起作用

标签 javascript menu hyperlink

我制作了一个 Accordion 菜单,大多数情况下一切正常。子菜单链接有效,滑动效果很好。问题是,没有子菜单的链接不起作用。我有一个 js 文件,其中包含以下代码片段:

$(document).ready(function(){   
$("#nav > li > a").on("click", function(e){ 
e.preventDefault();     
}
if(!$(this).hasClass("open")) { 
    // hide any open menus and remove all other classes                 
    // open our new menu and add the open class       
    $(this).next("ul").slideDown(350);       
    $(this).addClass("open");     
    }       
    else if($(this).hasClass("open")) {      
     $(this).removeClass("open");       
    $(this).next("ul").slideUp(350);     
    }  
     }); 
    }); 

正如您在顶部看到的那样,它声明如果 a 的父级有另一个子级 ul 则阻止该链接 a 打开,这对于具有子菜单的链接工作正常。然而,您会认为这仍然会使没有“ul”同级的链接起作用,但它们不起作用。例如,“调用我们”不会转到指定页面“open.htm”。我感谢任何帮助。谢谢。我的 html:

<div id="content">

    <div>
        <ul id="nav">
            <li><a href="#"><span class="block1"><img class="navicon" src="images/maps_30_white1.png" height="30" width="30" alt="Find Us" /><span class="button_desc">Find Us</span></span></a></li>
            <li><a href="open.htm#">Call Us</a></li>
            <li><a href="open.htm#"><span class="block1"><img class="navicon" src="images/clock_white1.png" height="30" width="30" alt="Opening Hours" /><span class="button_desc">Opening Hours</span></span></a></li> 
                <li><a href="#"><span class="block1"><img class="navicon" src="images/arrow_white.png" height="30" width="30" alt="Shop" /><span class="button_desc">Departments</span></span></a>  
                    <ul>
                        <li><h4><a href="http:/www.google.com/search?q=design+cartoons+animation">Cartoons</a></h4></li>
                        <li><h4><a href="http:/www.google.com/search?q=design+comic+strips+inspiration">Comic Strips</a></h4></li>
                        <li><h4><a href="http:/www.google.com/search?q=how+to+clip+video+footage">Video Clips</a></h4></li>
                        <li><h4><a href="http:/www.google.com/search?q=design+create+animated+gifs">Web GIFs</a></h4></li>
                    </ul>
                </li>
                <li><a href="#"><span class="block1"><img class="navicon" src="images/arrow_white.png" height="30" width="30" alt="Shop" /><span class="button_desc">Brands</span></span></a>
                    <ul>
                        <li><h4><a href="http:/www.google.com/search?q=photoshop+tutorials+graphics+design">Adobe Photoshop</a></h4></li>
                        <li><h4><a href="http:/www.google.com/search?q=digital+branding+graphics+logos">Branding & Logos</a></h4></li>

                    </ul>
                </li>
            <li><a href="#"><span class="block1"><img class="navicon" src="images/arrow_white.png" height="30" width="30" alt="Shop" /><span class="button_desc">Gift Ideas</span></span></a>
                    <ul>
                        <li><h4><a href="http:/www.google.com/search?q=photoshop+tutorials+graphics+design">Adobe Photoshop</a></h4></li>
                        <li><h4><a href="http:/www.google.com/search?q=digital+branding+graphics+logos">Branding & Logos</a></h4></li>
                        <li><h4><a href="http:/www.google.com/search?q=graphics+design+marketing">Digital Marketing</a></h4></li>

                    </ul>
                </li>
        </ul>
    </div>

</div>

最佳答案

首先,如果文本代表子菜单(例如:品牌),为什么它在 anchor 标记中?如果你想显示图像和一些文本,你可以使用 css 或 img 标签来实现。 删除 UL header 。

其次,您需要删除 e.preventDefault()。这就是为什么您的单个链接无法转到下一页的原因。

示例 HTML:

<div id="content">
    <div>
        <ul id="nav">
            <li><a href="www.google.com">Call Us</a>
            </li>
            <li><span class="block open">List Header</span>

                <ul>
                    <li>List item 1</li>
                    <li>List item ...</li>
                    <li>List item n</li>
                </ul>
            </li>
        </ul>
    </div>
</div>

CSS:

.block {
    text-decoration: underline;
}

你的固定 JS:

$(document).ready(function () {
    $("#nav > li > .block").on("click", function (e) {
        if (!$(this).hasClass("open")) {
            // hide any open menus and remove all other classes                 
            // open our new menu and add the open class       
            $(this).next("ul").slideDown(350);
            $(this).addClass("open");
        } else if ($(this).hasClass("open")) {
            $(this).removeClass("open");
            $(this).next("ul").slideUp(350);
        }
    });
});

现场演示/ fiddle :

http://jsfiddle.net/tRDzr/1/

关于javascript - 我做了一个 Accordion 菜单,但没有子菜单的链接不起作用,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/18729274/

相关文章:

javascript - Google 可视化图表对选择事件数据发出警报

javascript - 包含具有动态宽度的列表项的无序列表 - 水平菜单

css - WP + super 鱼 : Child menu item has hover/active applied when on parent page

html - 超链接标签事件状态不起作用

javascript - 调整大小时不显示 JQuery 切换 div

javascript - addEventListener 没有调用我的函数

android - NavigationView 中从右到左的菜单项 Android

html - 如何通过 CSS 显示多行长链接?

shell - 如何查找 PWD 中引用 PWD 之外的文件的所有符号链接(symbolic link)? UNIX

javascript - morris.js 单个标签上的多个堆叠条