jquery animate:一一改变元素的不透明度

Posted

技术标签:

【中文标题】jquery animate:一一改变元素的不透明度【英文标题】:jquery animate: change the element's opacity one by one 【发布时间】:2011-08-29 18:10:20 【问题描述】:

知道如何将每个特定元素的不透明度一一设置为最多 16 个目标/元素的动画吗?

这将改变元素的不透明度,

$('.block-item').animate(
        opacity:0
    ,500);

看看here。

但我希望不透明度一个接一个地改变。当它到达第 16 个元素时,这将停止。

这里是html

<div id="parent_container">

<div class="block-item">1</div>
<div class="block-item">2</div>
<div class="block-item">3</div>
<div class="block-item">4</div>
<div class="block-item">5</div>
<div class="block-item">6</div>
<div class="block-item">7</div>
<div class="block-item">8</div>
<div class="block-item">9</div>
<div class="block-item">10</div>
<div class="block-item">11</div>
<div class="block-item">12</div>
<div class="block-item">13</div>
<div class="block-item">14</div>
<div class="block-item">15</div>
<div class="block-item">16</div>
<div class="block-item">17</div>
<div class="block-item">18</div>

</div>

我推出了这个功能,但它会使任何浏览器崩溃,

function opacity_test(index)

    $('.block-item').eq( index ).animate(
        opacity:0
    ,500);

    setInterval( function() 
        opacity_test(index + 1);
    , 1000 );

谢谢。

【问题讨论】:

【参考方案1】:

试试这个:

var delay = 0;
$('.block-item:lt(16)').each(function() 
               //^^ do for every instance less than the 16th (starting at 0)
    $(this).delay(delay).animate(
        opacity:0
    ,500);
    delay += 500;
);

小提琴:http://jsfiddle.net/maniator/VS8tQ/3/

【讨论】:

【参考方案2】:

你可以使用.animate()的“完成回调”来开始下一次淡入淡出:

function fade(index) 
    $('.block-item').eq(index).animate(
        opacity: 0
    , function() 
        // on completion, recursively call myself
        // against the next element
        if (index < 15) 
            fade(index + 1);
        
    )


fade(0);

见http://jsfiddle.net/alnitak/3DuTG/

【讨论】:

@alnitak,没看到那里.. 嗯 @Neal FWIW 您的解决方案可能只需将.lt(16) 放在.each() 调用之前即可解决。 @alnitak 嗯,我会把它作为一个选项添加到我的答案中。 @Neal - 啊,这是不能作为函数使用的选择器之一:( @alnitak,我将它添加到选择器中【参考方案3】:

一个使用回调的选项,当它到达第 16 个元素时停止你可以使用.index()

var f = function($current) 
    $current.animate(
        opacity: 0
    , function() 
        if ($current.next(".block-item").index() < 15) 
            f($current.next(".block-item"));
        
    );
;

f($(".block-item:first"));

Example on jsfiddle

【讨论】:

以上是关于jquery animate:一一改变元素的不透明度的主要内容,如果未能解决你的问题,请参考以下文章

jQuery 效果方法

jQuery 常用的效果函数

jQuery效果

Jquery效果函数

自定义动画animate()

animate方法使用总结