JQuery Accordion: ссылки не работают - PullRequest
3 голосов
/ 02 декабря 2008

Я работаю над страницей, используя элемент пользовательского интерфейса JQuery . В этом примере я смоделировал свой 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 -->

Проблема: ссылки не работают

Во всех браузерах, которые я тестировал, ссылки в этих меню аккордеона приводят к тому, что секция аккордеона сворачивается вместо того, чтобы переходить на связанную страницу. (Я все еще могу щелкнуть правой кнопкой мыши и перейти на связанный сайт.)

Может быть, это какая-то проблема привязки кликов?

Ответы [ 9 ]

9 голосов
/ 02 декабря 2008

По умолчанию виджет аккордеона устанавливает все ссылки на заголовки. Чтобы изменить его, вам нужно указать селектор с опцией headers. Итак, ваш код будет выглядеть так:

$(".ui-accordion-container").accordion(
   { active: "a.default", ...,  header: "a.accordion-label" }
);
5 голосов
/ 16 июля 2013

Попробуйте добавить встроенный 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 и Google Closure, который имеет функции addEvent.

4 голосов
/ 28 июля 2009

У меня была точно такая же проблема, и я нигде не мог найти ответ. Фактически, пара источников сказала, что это просто невозможно сделать.

После дальнейшей игры я нашел рабочее решение. Может быть не очень хорошо, но это работает как шарм.

Во-первых, просто убедитесь, что ссылки, на которые вы хотите кликать, и которые защищены от управления аккордеоном, легко идентифицируются. У меня был класс на моем.

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

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

});

По сути, это прослушивается, когда нажимается ссылка внутри заголовка аккордеона. Когда это так, аккордеон временно отключен, что не позволяет ему стрелять как обычно. Затем ссылка открывается, в данном случае, в новом окне, но вы также можете использовать document.location

Если мы немедленно включим аккордеон, он все равно будет стрелять и переключать аккордеон. Я обнаружил, что супер-короткий тайм-аут обеспечивает достаточную задержку.

Надеюсь, это кому-нибудь поможет!

2 голосов
/ 26 октября 2009
0 голосов
/ 22 февраля 2012

Вот возможный альтернативный скрипт для тех, кто все еще сталкивается с этой проблемой: http://twostepmedia.co.uk/notes/development/jquery-accordion/

0 голосов
/ 15 июля 2010
0 голосов
/ 28 июля 2009

Может быть, я предлагаю не использовать функцию accordion (), [о которой я раньше не знал, спасибо, что поднял ее :)], но все же покажу, как получить элемент пользовательского интерфейса Accordion.

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>

Надеюсь, это поможет.

0 голосов
/ 19 мая 2009

AlwaysOpen должно быть истинным.

0 голосов
/ 02 декабря 2008

Как мой ответ на ваш другой вопрос говорит:

 navigation: true

Должен быть установлен в вашем списке опций.

...