gpt4 book ai didi

javascript - 将自动播放功能添加到简单的 jQuery slider

转载 作者:太空宇宙 更新时间:2023-11-03 23:19:34 25 4
gpt4 key购买 nike

我当前的 slider 功能完美,也有一个工作分页(分页点、事件状态和控件)但我只想添加一个新功能而不破坏任何东西:

我的 slider 在页面加载时自动播放的能力。

任何建议,非常感谢。

HTML/标记:

<div class="allslideshow">
<div class="slideshow-wrapper">
<div class="slide" id="s1"></div>
<div class="slide" id="s2"></div>
<div class="slide" id="s3"></div>
</div>
<div class="slideshow-nav"> <a href="#s1">•</a>
<a href="#s2">•</a>
<a href="#s3">•</a>
</div>
</div>

jQuery

jQuery(document).ready(function($) {
var Slideshow = {
paginate: function () {
var slides = $('div.slide', '.allslideshow'),
total = slides.length;
$('.slideshow-nav-total').text(total);
slides.each(function (i) {
$(this).data('index', i + 1);
});
},
navigate: function () {
$('a', '.slideshow-nav').click(function (e) {
e.preventDefault();
var $a = $(this);
var slide = $($a.attr('href'));
var wrapper = $('.slideshow-wrapper');
wrapper.animate({
left: -slide.position().left
}, 500, 'linear', function () {
$('.slideshow-nav-current').text(slide.data('index'));
$a.addClass('active').siblings('a').removeClass('active');
});

});
},
init: function () {
this.paginate();
this.navigate();
}
};
$(function () {
Slideshow.init();
});
});

尝试:

// autoplay: function () {
// .ready(function) {
// e.preventDefault();
// var $a = $(this);
// var slide = $($a.attr('href'));
// var wrapper = $('.slideshow-wrapper');
// wrapper.animate({
// left: -slide.position().left
// }, 300, 'linear', function () {
// $('.slideshow-nav-current').text(slide.data('index'));
// $a.addClass('active').siblings('a').removeClass('active');
// });

// });
// },

最佳答案

前进的方法是从链接上的“点击”事件处理程序中抽象出动画功能。这样您就可以从单击事件和计时器事件中调用动画函数。棘手的是,您必须捕获 this 上下文才能在闭包中使用它。这就是我的意思:

//...
moveTo: function($a) {
var slide = $($a.attr('href'));
var wrapper = $('.slideshow-wrapper');
wrapper.animate({
left: -slide.position().left
}, 500, 'linear', function () {
$('.slideshow-nav-current').text(slide.data('index'));
$a.addClass('active').siblings('a').removeClass('active');
});
},
navigate: function () {
var self = this;
$('a', '.slideshow-nav').click(function (e) {
e.preventDefault();
if (self.interval) {
clearInterval(self.interval);
self.interval = false;
}
var $a = $(this);
self.moveTo($a);
});
},
autoPlay: function() {
var $alist = $('a', '.slideshow-nav');
var i = 0;
var self = this;
this.interval = setInterval(function() {
var $a = $alist.eq(i++);
i %= $alist.length;
self.moveTo($a);
}, 1000);
},
init: function () {
this.paginate();
this.navigate();
this.autoPlay();
}
//...

Try it in a plunker .

关于javascript - 将自动播放功能添加到简单的 jQuery slider ,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/29265659/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com