jquery滑块自动启动功能

时间:2014-03-11 07:41:56

标签: javascript jquery

嗨朋友我的网站上有一个图像滑块

通过点击预览和下一个按钮来滑动图像。

我的问题是:是否可以添加自动启动而不是onclik?

这是我的代码:

  

      $(文件)。就绪(函数(){         var currentPosition = 0;         var slideWidth = 560;         var slides = $('。slide');         var numberOfSlides = slides.length;

  // Remove scrollbar in JS
  $('#slidesContainer').css('overflow', 'hidden');

  // Wrap all .slides with #slideInner div
  slides
    .wrapAll('<div id="slideInner"></div>')
    // Float left to display horizontally, readjust .slides width
  .css({
      'float' : 'left',
      'width' : slideWidth
    });

  // Set #slideInner width equal to total width of all slides
  $('#slideInner').css('width', slideWidth * numberOfSlides);

  // Insert controls in the DOM
  $('#slideshow')
    .prepend('<span class="control" id="leftControl">Clicking moves left</span>')
    .append('<span class="control" id="rightControl">Clicking moves right</span>');

  // Hide left arrow control on first load
  manageControls(currentPosition);

  // Create event listeners for .controls clicks
  $('.control')
    .bind('click', function(){
    // Determine new position
  currentPosition = ($(this).attr('id')=='rightControl') ? currentPosition+1 : currentPosition-1;

  // Hide / show controls
    manageControls(currentPosition);
    // Move slideInner using margin-left
    $('#slideInner').animate({
      'marginLeft' : slideWidth*(-currentPosition)
    });
  });

  // manageControls: Hides and Shows controls depending on currentPosition
  function manageControls(position){
    // Hide left arrow if position is first slide
  if(position==0){ $('#leftControl').hide() } else{ $('#leftControl').show() }
  // Hide right arrow if position is last slide
    if(position==numberOfSlides-1){ $('#rightControl').hide() } else{ $('#rightControl').show() }
  }   
});
</script>

2 个答案:

答案 0 :(得分:0)

正如melc提到的那样。您只需使用计时器即可实现自动启动或幻灯片效果。以下代码对您来说是一个很好的起点,但是您可能希望更新它以添加停止/启动功能,返回开始......

$(document).ready(function(){
    //auto start after 3 seconds
    setTimeout(function(){
        $('.control').click();
    },3000);

    //slideshow - every 3 seconds
    var slider = setInterval(function(){
        $('.control').click();
    },3000);

});

希望这有帮助

答案 1 :(得分:0)

您可以将点击功能分离到其他功能,然后间隔调用它。 This jsfiddle 显示了一个简单的示例。

var rotation = 90;
function doAnim()
{
    var rotationString = 'rotateY(' + rotation + 'deg)'
    $('#slideOne').css('webkit-transform',rotationString);
    $('#slideTwo').css('webkit-transform',rotationString);
    $('#slideOne').css('transform',rotationString);
    $('#slideTwo').css('transform',rotationString);    
    rotation += 90;
}

$(function(){    
    setInterval(doAnim,1000);
});

如果您使用的是jquery 1.7+,那么您可能需要考虑将bind事件更改为on。请参阅on文档here

  

从jQuery 1.7开始,.on()方法是将事件处理程序附加到文档的首选方法。