4

我正在使用 jQuery 的手风琴 UI 元素处理页面。我在那个例子上建模了我的 HTML,除了在<li>元素内部,我有一些无序列表的链接。像这样:

  $(document).ready(function() {
     $(".ui-accordion-container").accordion(
        {active: "a.default", alwaysOpen: true, autoHeight: false}
     );
  });

  <ul class="ui-accordion-container">
  <li> <!-- Start accordion section -->
   <a href='#' class="accordion-label">A Group of Links</a>
   <ul class="linklist">
      <li><a href="http://example.com">Example Link</a></li>
      <li><a href="http://example.com">Example Link</a></li>
   </ul>

   <!--and of course there's another group -->

问题:链接不起作用

在我测试过的所有浏览器中,这些手风琴菜单中的链接会导致手风琴部分折叠,而不是将您带到链接页面。(我仍然可以右键单击并转到链接的站点。)

这可能是某种点击绑定问题吗?

4

9 回答 9

10

默认情况下,accordian 小部件将所有链接设置为标题。要更改它,您需要指定带有headers选项的选择器。因此,您的代码将如下所示:

$(".ui-accordion-container").accordion(
   { active: "a.default", ...,  header: "a.accordion-label" }
);
于 2008-12-01T22:57:22.690 回答
8

尝试添加防止事件冒泡的内联 onlick:

...
<a href='#' onclick="event.stopPropagation()" class="accordion-label">A Group of Links</a>
...

或者像这样的 domready 事件:

$(".toggle-title a").click(function(event){ event.stopPropagation()})

然而后者对我不起作用,即使代码明智它是有道理的,jQuery 执行点击!任何可以向我解释的人都可以放心,我来自 MooTools 和具有 addEvent 功能的 Google Closure 背景。

于 2013-07-16T16:34:18.133 回答
4

我遇到了同样的问题,在任何地方都找不到答案。事实上,一些消息人士表示,这只是无法完成。

进一步玩后,我确实找到了一个可行的解决方案。可能不是很好,但它就像一个魅力。

首先,只需确保您希望可点击且不受手风琴控件影响的链接易于识别。我有我的课。

 $('.stats a').click(function(){
expander.accordion('disable');
window.open($(this).attr('href'));

setTimeout ( function() {
  expander.accordion('enable');
}, 250 );

});

本质上,这会监听手风琴标题内的链接何时被单击。如果是这样,手风琴会暂时禁用,使其无法正常发射。然后在新窗口中打开链接,但您也可以使用 document.location

如果我们立即重新启用手风琴,它仍然会触发并切换手风琴。我发现超短超时提供了足够的延迟。

希望这对某人有帮助!

于 2009-07-28T17:23:50.227 回答
2

这是一个非常简单的解决方案

http://www.designerstalk.com/forums/help-me/41297-jquery-accordion-embedding-links-help-needed.html

于 2009-10-25T23:10:53.913 回答
0

AlwaysOpen 应该是真的。

于 2009-05-19T11:34:57.863 回答
0

可能是我的建议是不使用手风琴()函数,[我以前不知道,谢谢你提出来 :)] 但仍然展示了如何拥有手风琴 UI 元素。

HTML

<body id="body">
    <h2>Accordian</h2>
        <div id="accordion" class="">

                <div class="toggle_all">
                        <ul class="links">
                                <li><a class="openall" href="#"><span>Open All</span></a></li>
                                <li>|</li>
                                <li><a class="closeall" href="#"><span>Close All</span></a></li>
                        </ul>
                </div>

                <!-- toggleAll ends -->
                <div class="accordion">
                        <div class="section_title_accordion design-gray">
                                <h3><a href="#" class="open"><span>Lorem ipsum</span></a></h3>
                        </div>
                        <!-- section_title_accordion ends -->
                        <div class="accordion_content"> <span class="content">Lorem ipsum dolor sit amet, consectetur adipisicing elit, sed do eiusmod tempor incididunt ut labore et dolore magna aliqua.</span> </div>

                        <!-- accordion_content ends -->
                </div>
                <!-- accordion ends -->
                <div class="accordion">
                        <div class="section_title_accordion design-gray">
                                <h3><a href="#" class="open"><span>Lorem ipsum</span></a></h3>
                        </div>
                        <!-- section_title_accordion ends -->

                        <div class="accordion_content"> <span class="content">Lorem ipsum dolor sit amet, consectetur adipisicing elit, sed do eiusmod tempor incididunt ut labore et dolore magna aliqua.</span> </div>
                        <!-- accordion_content ends -->
                </div>
                <!-- accordion ends -->
                <div class="accordion">
                        <div class="section_title_accordion design-gray">
                                <h3><a href="#" class="open"><span>Lorem ipsum</span></a></h3>

                        </div>
                        <!-- section_title_accordion ends -->
                        <div class="accordion_content"> <span class="content">Lorem ipsum dolor sit amet, consectetur adipisicing elit, sed do eiusmod tempor incididunt ut labore et dolore magna aliqua.</span> </div>
                        <!-- accordion_content ends -->
                </div>
                <!-- accordion ends -->
        </div>

        <!-- #accordion ends -->
</body>

CSS

<style type="text/css" >
#body { margin-left:20%; font:12px verdana; }
.accordion { width:500px; }
h3 { margin:0; padding:0; }
.section_title_accordion { float:left; width:500px; margin:2px 0 0; }
.section_title_accordion h3 span { margin:0; float:left; color:#fff; padding:2px 0 3px 10px; }
.section_title_accordion a span { padding-left:20px; }
.accordion_content { border-bottom:1px solid #666666; border-left:1px solid #666666; border-right:1px solid #666666; float:left; padding:5px 3px; }
.accordion_content span.content { margin:5px 0 0; }
.design-gray { background:#003366; }
.design-gray a { color:#fff; float:left; width:100%; height:22px; background:#003366; text-decoration:none; }
.design-gray a:hover { text-decoration:underline;}
.on .design-gray a { color:#fff; float:left; width:100%; height:22px; background:#003366;}
.accordion_content_hover { background:#ffffcc; color:#000099; }
.toggle_all { padding:20px 0; width:500px; margin-bottom:5px; }
.toggle_all ul { padding:0; margin:0; }
.toggle_all ul li { list-style-type:none; }
.toggle_all .links li { float:left; padding-left:5px; }
.toggle_all .links li a, .toggleAll .links span { color:#666666; }
</style>

jQuery

<script language="javascript" type="text/javascript">

$(document).ready(function() {
  $(".accordion_content").hide();
  $("a.open").click(function() {
    $(this).parents(".accordion").find(".accordion_content").toggle();
        $(this).parents(".accordion").toggleClass('on');    
        return false;
  });   

    $(".accordion_content").mouseover(function() {
            $(this).addClass('accordion_content_hover');
            return false;       
    });

    $(".accordion_content").mouseout(function() {
            $(this).removeClass('accordion_content_hover');
            return false;       
    });

    $("a.openall").click(function() {
        $(".accordion_content").show();
        $(this).parents("#accordion").find(".accordion").addClass('on');
        return false;
    });
    $("a.closeall").click(function() {
          $(".accordion_content").hide();
          $(this).parents("#accordion").find(".accordion").removeClass('on');
        return false;
    });
});
</script>

希望这可以帮助。

于 2009-07-28T17:49:31.860 回答
0

解决方案 http://www.colorizate.com/jquery-acordion-hack-link-interno/

于 2010-07-15T00:49:40.620 回答
0

对于仍然遇到此问题的任何人,这是一个可能的替代脚本:http: //twostepmedia.co.uk/notes/development/jquery-accordion/

于 2012-02-22T11:01:11.660 回答
-1

正如我对您的另一个问题的回答所说:

 navigation: true

应该在您的选项列表中设置。

于 2008-12-01T22:45:03.993 回答