1

我有以下 HTML:

<div class="connections">
    <h2>Grads that share your interests</h2>
        <div id="connections_nav" class="collapse">
            <ul>
            <li><h3><a href="">Sally Struthers </a></h3><p>Class of 2008</p></li> 
                <li><h3><a href="">Sally Struthers </a></h3><p>Class of 2008</p>
                                </li>
            <li><h3><a href="">Sally Struthers </a></h3><p>Class of 2008</p>
                                </li> 
            </ul>
        </div>
</div> 

以及以下 CSS:

.connections h2 {
    background-image: url(images/show.gif);
    background-position: 0px;
    background-repeat: no-repeat;
    color: #660a11;
    font-size: 13px;
    font-weight: bold;
    margin: 0px 0px .4em;
    padding: 0px 0px 0px 25px; }

.connections .hide h2 {
    background-image: url(images/hide.gif);
    background-position: 0px;
    background-repeat: no-repeat; }

.connections h2.over {
    background-image: url(images/hover-show.gif);
    background-position: 0px;
    background-repeat: no-repeat; }

.connections .hide h2.over {
    background-image: url(images/hover-hide.gif);
    background-position: 0px;
    background-repeat: no-repeat; }

使用以下 jQuery:

$(document).ready(function() {

$('.connections h2').click(function() {
    $(this).parent().children('.collapse').toggle('slow');
    $(this).toggleClass('hide');
});

$('.connections h2').hover( 
    function() {
        $(this).toggleClass('over');
      },
      function () {
        $(this).toggleClass('over');
});

});

发生的事情是整个 div 消失了。当我取出$(this).toggleClass('hide');代码时,折叠 div 正确折叠(但显然没有应用显示闭合三角形图像的“隐藏”类)。这是为什么?

4

1 回答 1

1

$(this).toggleClass('hide')变为。<h2></h2>_<h2 class="hide"></h2>

因此,正确的 CSS 选择器应该是:

.connections h2.hide {}
.connections h2.hide.over {}

工作示例:http: //jsfiddle.net/PTnXU/

如果您在和之间有另一个元素,那么您的原始选择器.connections .hide h2.over会很好,例如:<div><h2>

<div class="connections">
  <div class="hide">
    <h2 class="over"></h2>
  </div>
</div>
于 2011-11-17T07:24:00.547 回答