繁体   English   中英

在ul li上滑动切换

[英]slide toggle on ul li

我在控制我的slidetoggle时遇到问题,我想显示我徘徊的年份中的月份,但是当我将鼠标悬停在2015年时,2014年的月份也是如此,我该怎么做。

样品小提琴

HTML:

<ul class="year">
    <li>2015
        <ul class="months">
            <li>Jan</li>
            <li>feb</li>
        </ul>
</li>
    <li>2014
        <ul class="months">
            <li>march</li>
            <li>april</li>
        </ul>
</li>
</ul>

CSS:

.months { display: none; }

脚本:

   $(".year").hover(function () {
    $(".months").slideToggle("slow");
});

您需要使选择器更加具体(找到悬停li直接后代的孩子months )。 另外,您还有无效的html( ul不能直接嵌套在另一个ul )。

尝试:

//Bind event on the `li` that is direct descendant of .year
$(".year > li").hover(function () {
    //Get its direct descendant `.months` and toggle
    $(this).children(".months").stop(true).slideToggle("slow");
});

<ul class="year">
    <li>2015
        <ul class="months">
            <li>Jan</li>
            <li>feb</li>
        </ul>
    </li>
    <li>2014
        <ul class="months">
            <li>march</li>
            <li>april</li>
        </ul>
    </li>
</ul>

小提琴

包装标签并使用同级选择器的另一个示例:

$(".year > li > span").hover(function (e) {
    $(this).next().stop(true).slideToggle("slow");
});

<ul class="year">
    <li><span>2015</span>
        <ul class="months">
            <li>Jan</li>
            <li>feb</li>
        </ul>
    </li>
    <li><span>2014</span>
        <ul class="months">
            <li>march</li>
            <li>april</li>
        </ul>
    </li>
</ul>

小提琴

暂无
暂无

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

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