添加幻灯片按钮 - jquery

时间:2013-08-16 14:10:04

标签: jquery css slideshow

我在这里有一个非常简单的幻灯片:http://jsfiddle.net/Jtec5/2/
这是代码:
HTML:

<div id="slideshow">
    <div>
        <img src="http://farm6.static.flickr.com/5224/5658667829_2bb7d42a9c_m.jpg">
    </div>
    <div>
        <img src="http://farm6.static.flickr.com/5230/5638093881_a791e4f819_m.jpg">
    </div>
    <div>
        <img src="http://gillespaquette.ca/images/stack-icon.png">
    </div>
</div>
<ul></ul>

CSS:

#slideshow {
    margin: 50px auto;
    position: relative;
    width: 240px;
    height: 240px;
    padding: 10px;
    box-shadow: 0 0 20px rgba(0, 0, 0, 0.4);
}
#slideshow > div {
    position: absolute;
    top: 10px;
    left: 10px;
    right: 10px;
    bottom: 10px;
}

#slideshow img {
    max-width:240px;
    max-height:240px;
}

ul {
    list-style:none;
    margin:0px;
    padding:0px;
}
ul li {
    float:left;
    border-radius:10px;
    width:10px;
    height:10px;
    border:1px solid white;
    background:grey;
}
ul li.active {
    background:black;
}

Jquery的:

$("#slideshow > div:gt(0)").hide();

var index = 1;
var maxindex = $('#slideshow > div').length;

setInterval(function () {
    $('#slideshow > div:first')
        .fadeOut(1000)
        .next()
        .fadeIn(1000)
        .end()
        .appendTo('#slideshow');
    $('ul li').removeClass('active');
    $('ul li:eq(' + index + ')').addClass('active');
    index = index < maxindex - 1 ? index + 1 : 0;
}, 3000);

for (var i = 0; i < maxindex; i++) {
    $('ul').append('<li class="' + (i == 0 ? 'active' : '') + '"></li>');
}

你可以在幻灯片中看到按钮告诉我我在哪张照片中,我正在尝试将每个按钮与其照片联系起来,所以当我点击它时它会将我带到它的照片,如果更改了整个代码需要按钮会更好,因为我不喜欢我的代码,我觉得它太长了。

2 个答案:

答案 0 :(得分:2)

我也做了一个小提琴,希望能做到你想要的。 http://jsfiddle.net/L7s4e/ 主要代码如下:

  $("#slideshow > div:gt(0)").hide();

  index = 0;
  maxIndex = $('#slideshow > div').length;

  $mainDiv = $('#slideshow div');
  for (var i = 0; i < maxIndex; i++) {
      var $li = $("<li/>", {
          "data-index": i,
          "class": (i == 0 ? 'active' : '')
      }).on("click",

      function () {
          /* uncomment below if you want slideshow to stop on selection
    to restart call startSlideshow();*/
          //clearInterval(intervalId);
          var imageIndex = $(this).data("index");
          $mainDiv.eq(index).fadeOut(1000);
          $mainDiv.eq(imageIndex).fadeIn(1000);
          index = imageIndex;
          $('ul li').removeClass('active');
          $('ul li:eq(' + index + ')').addClass('active');
      });

      $('ul').append($li);
  }

  function startSlideshow() {

      intervalId = setInterval(function () {
          $('#slideshow > div').eq(index).fadeOut(1000);
          index = index < maxIndex - 1 ? index + 1 : 0;
          $('#slideshow > div').eq(index).fadeIn(1000);
          $('ul li').removeClass('active');
          $('ul li:eq(' + index + ')').addClass('active');
      }, 3000);
  }

  startSlideshow();

希望它能按你的意愿运作。 R上。

答案 1 :(得分:0)

见以下内容:

var $mainDiv  = $('#slideshow div');
for (var i = 0; i < maxindex; i++) {
        var $li = $("<li/>",{"data-index":i, "class":(i == 0 ? 'active' : '')})
                  .on("click",function(){
                        var imageIndex = $(this).data("index");
                        $mainDiv.eq(imageIndex).fadeIn(1000).prev().fadeOut(1000);
                  });

    $('ul').append($li);
}

在这里工作小提琴:http://jsfiddle.net/Jtec5/36/

我希望它有所帮助