简体   繁体   English

简单的手风琴菜单(jQuery)

[英]Simple accordion menu (jQuery)

jQuery: jQuery的:

// ACCORDION
$('.accordion .answer').hide(); // hide all
$('.accordion .question').click(function(){
     $('.accordion .answer').slideUp(); // hide all open
     $(this).addClass('active').next().slideDown(); // show the anwser
     return false;
});

HTML: HTML:

<dl class="accordion">
    <dt class="question">question</dt>
    <dd class="answer">answer</dd>
    <dt class="question">question</dt>
    <dd class="answer">answer</dd>
</dl>

... works, but ...有效,但是

  • The 'active' class must be removed from inactive question elements & 必须从无效的问题元素中删除“有效”类,
  • At least one of the answers remains open; 至少有一个答案是公开的; all answers should be able to close. 所有答案都应该能够结束。

Thanks! 谢谢!

$('.accordion .answer').hide(); // hide all
$('.accordion .question').click(function(){
    if($(this).hasClass('active')) {
        $(this).removeClass('active').next().slideUp();
    } else {
        $('.accordion .answer').removeClass('active').slideUp();
        $(this).addClass('active').next().slideDown();
    }
    return false;
});

But you should really take a look at the jQuery UI Accordion . 但是您应该真正看一下jQuery UI Accordion

Okay, figured it: 好吧,想通了:

$('.accordion .answer').hide(); // hide all
$(".accordion .question").click(function () {
    $(this).toggleClass('active').next(".answer").slideToggle(300).siblings(".answer").slideUp("slow");
    $(this).siblings().removeClass('active');
});

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM