使用Slick.js-如何删除当前的 Activity 幻灯片?我举了一个例子,但是没有用
var $status = $('.pagingInfo');
var $slickElement = $('.slideshow');
$slickElement.on('init reInit afterChange', function (event, slick, currentSlide, nextSlide) {
//currentSlide is undefined on init -- set it to 0 in this case (currentSlide is 0 based)
var i = (currentSlide ? currentSlide : 0) + 1;
$status.text(i + '/' + slick.slideCount);
});
$slickElement.slick({
slide: 'img',
speed: 1,
infinite: false,
swipe: false,
autoplay: false,
dots: false
});
$('.remove-slide').on('click', function() {
$slickElement.slick('slickRemove', i);
});
我的小提琴在这里-http://jsfiddle.net/q5yae1t3/9/
最佳答案
您没有在i
函数中设置$(...).on(...)
变量。您需要设置i
才能删除基于i
的内容。然后,您还需要更改所有data-slick-index
属性,因为在更改幻灯片计数器时这些属性没有更改。
$('.remove-slide').on('click', function() {
i = $("img.slick-active").attr("data-slick-index");
$slickElement.slick('slickRemove', i);
var j = 0;
$("img.slick-slide").each(function(){
$(this).attr("data-slick-index",j);
j++;
});
});
http://jsfiddle.net/q5yae1t3/19/
希望有帮助!