嗨朋友我的网站上有一个图像滑块
通过点击预览和下一个按钮来滑动图像。
我的问题是:是否可以添加自动启动而不是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>
答案 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()方法是将事件处理程序附加到文档的首选方法。