使用jquery在幻灯片中显示FadeIn()图像

时间:2014-03-15 21:58:42

标签: javascript css background fadein fadeout

我正在制作图片幻灯片,并且每个图片的fadeOut()功能都会发生变化,但下一张图片会突然出现。我希望它能够消失。我似乎无法让它发挥作用。

以下是没有任何fadeIn()的代码:

HTML:

<div id="backgroundChanger">
  <img class="active" src="background1.jpg"/>
  <img src="background2.jpg"/>  
  <img src="background3.jpg"/>  

CSS:

#backgroundChanger{
 position:relative;
}
#backgroundChanger img{
 position:absolute;
 z-index:-3
}
#backgroundChanger img.active{
 z-index:-1;
}

使用Javascript:

function cycleImages(){
      var $active = $('#backgroundChanger .active');
      var $next = ($active.next().length > 0) ? $active.next() : $('#backgroundChanger img:first');
      $next.css('z-index',-2);
      $active.fadeOut(1500,function(){
      $active.css('z-index',-3).show().removeClass('active');
          $next.css('z-index',-1).addClass('active');
      });
    }

$(document).ready(function(){
 setInterval('cycleImages()', 7000);
})

2 个答案:

答案 0 :(得分:0)

我推荐这样的间隔功能:

window.setInterval(function (){
  var images = $('#backgroundChanger img');
  var active, next;

  images.each(function(index, img) {
    if($(img).hasClass('active')) {
      active = index;
      next = (index === images.length - 1) ? 0 : index + 1;
    }
  });

  $(images[active]).fadeOut(1000, function() {
    $(images[next]).fadeIn(1000);
  });

  $(images[next]).addClass('active');
  $(images[active]).removeClass('active');
}, 3000);

这就是你需要的所有css:

#backgroundChanger img:first-child {
  display: block;
}

#backgroundChanger img {
  display: none;
}

保持相同的HTML,你应该好好去!

答案 1 :(得分:0)

您可以fadeIn() fadeOut()回调中的下一张图片,如下所示:

&#13;
&#13;
$(window).load(function() {
  var $slider = $("#backgroundChanger"),
    $slides = $slider.find("img"),
    $firstSlide = $slides.first();

  function cycleImages() {
    var $active = $('#backgroundChanger .active'),
      $next = ($active.next().length > 0) ? $active.next() : $firstSlide;
    $active.fadeOut(1000, function() {
      $active.removeClass('active');
      $next.fadeIn(1000).addClass('active');
    });
  }

  setInterval(cycleImages, 3000);
})
&#13;
#backgroundChanger img {
  position: absolute;
  width: 150px;
  height: 100px;
}
&#13;
<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script>
<div id="backgroundChanger">
  <img class="active" src="http://i46.tinypic.com/2epim8j.jpg" />
  <img src="http://i49.tinypic.com/28vepvr.jpg" />
  <img src="http://i50.tinypic.com/f0ud01.jpg" />
</div>
&#13;
&#13;
&#13;

注意:

  • 由于我们正在处理图片,因此最好使用load()处理程序而不是ready()以确保幻灯片放映在图片加载后启动
  • 您可以通过缓存经常访问的元素来略微提高性能
  • 您根本不必使用z-index属性,因为fadeIn()fadeOut()都会更改元素`display property own