【问题标题】:fade changing image every n seconds每 n 秒淡出改变图像
【发布时间】:2013-09-25 04:07:10
【问题描述】:

我想每 3 秒更改一次图像,但是在更改时我想制作淡入淡出效果,这样做我正在做:

  <script type="text/javascript">
    var images = [];
    images[0] = "http://i2.ytimg.com/vi/Q1yo3mco40U/default.jpg";
    images[1] = "http://i2.ytimg.com/vi/ivmoCcYLrEk/default.jpg";
    images[2] = "http://i3.ytimg.com/vi/f7d8luQ6p2Q/default.jpg";
    images[3] = "http://i1.ytimg.com/vi/XzFmOKNf8sc/default.jpg";
    images[4] = "http://i2.ytimg.com/vi/-2m1e4g2MFM/default.jpg";
    images[5] = "http://i1.ytimg.com/vi/lK2TSYBh7fw/default.jpg";
    var loop;
    var i = 0;

    $(document).ready(function() {
        setTimeout(fadeDivs, 3000);   
    });

    function fadeDivs()
    {
        $('.product img').attr('src',images[i]).fadeOut(100);
        if (i < images.length - 1) {
            i++;                                
        } else {
            i = 0;                
        } 
    }
  </script>

和:

<section id="product">
    <article class="product">
      <img src="http://i2.ytimg.com/vi/Q1yo3mco40U/default.jpg" />
    </article>
</section>

但是不起作用,我认为问题出在

$('.product img').attr('src',images[i]).fadeOut(100);

有没有更好的方法来做到这一点?

here is jsfiddle

【问题讨论】:

  • 在您的小提琴中,缺少 jQuery 包含.. 补充一下。

标签: jquery html fade


【解决方案1】:

您需要使用 fadeIn()fadeOut() 以及完整的回调来完成此操作

var images = [];
images[0] = "http://i2.ytimg.com/vi/Q1yo3mco40U/default.jpg";
images[1] = "http://i2.ytimg.com/vi/ivmoCcYLrEk/default.jpg";
images[2] = "http://i3.ytimg.com/vi/f7d8luQ6p2Q/default.jpg";
images[3] = "http://i1.ytimg.com/vi/XzFmOKNf8sc/default.jpg";
images[4] = "http://i2.ytimg.com/vi/-2m1e4g2MFM/default.jpg";
images[5] = "http://i1.ytimg.com/vi/lK2TSYBh7fw/default.jpg";

var i = 0;
setInterval(fadeDivs, 3000);

function fadeDivs() {
    i = i < images.length ? i : 0;
    $('.product img').fadeOut(100, function(){
        $(this).attr('src', images[i]).fadeIn(100);
    })
    i++;
}

演示:Fiddle

注意:在小提琴中,你错过了包含 jQuery

【讨论】:

  • 如何设置间隔?有必要吗?
  • @cMinor 对不起...你是什么意思...使用setInterval是因为必须定期调用函数fadeDivs
  • 轻微的 JS 异步错误...当匿名函数(传递给 fad​​eOut 调用)运行时,i 的值已经向前移动,因此您实际上正在查看下一张图像 (i++)功能块内的 i++; 解决了问题
猜你喜欢
  • 2013-06-19
  • 1970-01-01
  • 2020-02-18
  • 2012-05-15
  • 1970-01-01
  • 2012-04-15
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
相关资源
最近更新 更多