8

我想知道如何为 JQuery addClass/removeClass 函数设置动画?

对于动画功能,似乎我必须放置一些 CSS 属性,但是如果我有一个类使每次触发单击功能时元素显示为块,而所有元素在 CSS 中显示为隐藏。如何为这个过程设置动画?

这是我的代码:

<script src="js/jquery-1.9.1.min.js"></script>
<script>

    var allSlides = $('li');

    $('#nextSlide').click(function(){
        var nextSlide = $('.active').next();
        if (nextSlide.length == 0)
        {
            var nextSlide = allSlides.first();
        }
        $('.active').removeClass('active');
        nextSlide.addClass('active');
        return false;
    });

    $('#prevSlide').click(function(){
        var prevSlide = $('.active').prev();
        if (prevSlide.length == 0)
        {
            var prevSlide = allSlides.last();
        }
        $('.active').removeClass('active');
        prevSlide.addClass('active');
        return false;
    });

</script>
4

4 回答 4

15

您可以将 CSS3 过渡属性应用于使用 jQuery 操作的元素。这是一个带有供应商前缀的示例:

element {
    -webkit-transition: all 2s; // Chrome
    -moz-transition: all 2s; // Mozilla
    -o-transition: all 2s; // Opera
    transition: all 2s;
}
于 2013-03-26T15:24:12.970 回答
2

如果你使用 jQueryUI,你可以使用 $.toggleClass(); 功能。

http://api.jqueryui.com/toggleClass/

于 2013-03-26T15:49:46.133 回答
1

你可以使用 jQuery .fadeIn()或者你可以使用 CSS3 过渡:

#nextSlide, #prevSlide {
  display: none;
  -webkit-transition: display .5s ease;
  -moz-transition: display .5s ease;
  -o-transition: display .5s ease;
}
.active {
  transition: display .5s ease;
  -webkit-transition: display .5s ease;
  -moz-transition: display .5s ease;
  -o-transition: display .5s ease;
}

那应该对你有用。您可以通过替换display转换样式来添加任何其他转换。

于 2013-03-26T15:28:42.580 回答
0

您绝对可以使用 jquery 为添加/删除类设置动画。请检查以下格式

.removeClass( className [, duration ] [, easing ] [, complete ] )

下面的示例代码

$( "div" ).click(function() {
   $( this ).removeClass( "big-blue", 1000, "easeInBack" );
});

参考链接

注意:但是您必须添加jquery-ui.js文件才能使其工作。

<script src="http://code.jquery.com/ui/1.11.4/jquery-ui.js"></script>

希望这会有所帮助。谢谢

于 2016-08-11T19:38:55.690 回答