1

我有这个代码:

jQuery('#flash').animate({opacity: 0.35}, 200)
                .animate({opacity: 0}, 200)
                .animate({opacity: 0.35}, 200)
                .animate({opacity: 0}, 200)
                .animate({opacity: 0.35}, 200)
                .animate({opacity: 0}, 600)

而且我还没有决定要改变它的状态多少次。有没有办法以编程方式链接动画,而不必通过编辑动画链来添加/删除链元素?

4

4 回答 4

2

如果我理解正确,您只需要一个 FOR 循环:

function animate_n_times(n) {
   var flash = $('#flash');
   for(var i=0;i<n;i++) {
      flash.animate({opacity: 0.35}, 200)
           .animate({opacity: 0}, 200);
   }

}

然后像这样调用:

animate_n_times(3);
于 2012-09-15T10:56:07.170 回答
2

不,您不能在不编辑动画队列的情况下链接动画。如果您想链接一个变量,但次数有限,您可以使用循环轻松完成:

var flash = $("#flash");
for (var i=0; i<n; i++)
    flash.animate({opacity: 0.35}, 200).animate({opacity: 0}, 200);

如果您想要一个无限循环,或者在将来满足某个条件时停止循环,您希望在动画队列上挂钩回调,重新启动函数:

var flash = $("#flash");
function anim() {
    // if (condition)
    flash.animate({opacity: 0.35}, 200).animate({opacity: 0}, 200, anim);
                                            // call "recursively": ^^^^
}
anim();
于 2012-09-15T11:16:38.670 回答
1

如果您正在寻找,您可以使用循环链接动画。

var $flash = jQuery('#flash'), i;

for (i = 0; i < 10; i++) {
    $flash = $flash.animate({opacity: 0.35}, 200)
                   .animate({opacity: 0}, 200);
}
于 2012-09-15T10:49:46.557 回答
0

有一个更短的选择,使用扩展jquery-timing

动画给定次数:

$('#flash').repeat().animate({opacity:0.35}, 200)
    .animate({opacity:0}, 200).until(10);

作为无限循环:

$('#flash').repeat().animate({opacity:0.35},200).animate({opacity:0},200,$);

有关详细信息,请参阅.repeat().until(count).animate(...,$)的 API 。

于 2012-09-19T10:28:24.300 回答