1

我有这个 HTML:

<div id="parent1" class="article">
   <div class="action"></div>
   <div id="exp1" class="expand"></div>
</div>
<div id="parent2" class="article">
   <div class="action"></div>
   <div id="exp2" class="expand"></div>
</div>

和 CSS:

.article:hover .action {
   z-index:1000;
}
.expand {
   display: none;
} 
action {
   background: url(../images/down.png) 0 0 no-repeat;
   z-index: -999;
}
.collapse {
   background: url(../images/up.png) 0 0 no-repeat !important;
   z-index: 1000;
}

和 Javascript:

$(".article").click(function() {
   $(this).find(".action").toggleClass("collapse"); // works onclick div article
   ????????? // when press parent1 if parent2 pressed before ???????.find(".action").toggleClass("collapse");
   $("#exp2").hide(); // if previously open
   $("#exp1").toggle(300);
}

现在我需要 jQuery for onclick parent1 在 parent2 中切换类操作,但前提是之前切换到折叠。

4

2 回答 2

0

有很多方法可以做到这一点。通常我会存储一个保存下拉状态(布尔值)的局部变量,然后检查它。

使用 jQuery,由于您已经在使用 hide(),您可以使用:

if ($("#exp2").is(":hidden")) {
    // Show content, set arrow to up.
    $("#exp2").removeClass("expand").addClass("collapse");
}
else {
    // Hide content, set arrow to down.
    $("#exp2").removeClass("collapse").addClass("expand");
}

如果您只是添加和删除一个类,则切换会更有意义。在这里,您是交替上课。使用 addClass() 和 removeClass() 可以很清楚你在做什么。

于 2011-12-11T04:47:08.287 回答
0

我在这里猜测,但我认为您想关闭任何打开的 .article 并打开您单击的那个。

$(".article").click(function() {
   // see explanations 1 and 2 below
   $('.article.active').removeClass('active').find('#exp1').hide();

   // see explanation 3 below
   $(this).addClass('active').find('#exp2').show();
}

您可以更改代码以满足您的需要,但您可以理解它:

  1. 当我们单击 .article 时,我们会查找具有特定类的任何其他 .article(在我的示例中为 .active)。从技术上讲,可能只有一个 .article.active
  2. 我们删除它的 .active 类并对它或它的孩子做任何事情
  3. 我们终于在点击的文章上做任何事情
于 2011-12-11T05:34:45.843 回答