Jquery滑块自动启动功能

jquery slider auto start function

本文关键字:功能 自动启动 Jquery      更新时间:2023-09-26

我的网站上有一个图片滑块

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

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

下面是我的代码:

$(文档)时函数(){var currentPosition = 0;var slideWidth = 560;Var slides = $('.slide');var numberOfSlides =幻灯片长度;

  // 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>

您可以将点击中的功能分离为不同的函数,然后隔一段时间调用它。这个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文档

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

如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);
});

希望能有所帮助