中心活动幻灯片,在slick.js中显示3张幻灯片

时间:2016-05-03 14:25:52

标签: javascript jquery html css slick.js

我正在使用slick.js插件,我想在他们的网站上制作类似的内容。这是DEMO

问题是,第一个活动幻灯片1未居中。我知道我可以使用

$('.slider-nav').slick({
    slidesToShow: 3,
    slidesToScroll: 1,
    asNavFor: '.slider-for',
    dots: true,
    focusOnSelect: true,
    centerMode: true
});

但是没有3张幻灯片,还有另外2张幻灯片的部分,请参阅HERE

2 个答案:

答案 0 :(得分:2)

嗯,这太尴尬了。只需将centerPadding选项设置为0即可。我不知道为什么我以前没见过这个。无论如何,这是我的1个月更新:

<强> WORKING DEMO

答案 1 :(得分:1)

如果我正确理解您的问题,您将不得不以编程方式隐藏部分幻灯片。如果这个功能本身存在会很棒,但事实并非如此。也许在将来的版本中。

请阅读评论,以简要概述我正在做的事情:

function setSlideVisibility() {
  //Find the visible slides i.e. where aria-hidden="false"
  var visibleSlides = $('.slider-nav > .slick-list > .slick-track > .slick-slide[aria-hidden="false"]');
  //Make sure all of the visible slides have an opacity of 1
  $(visibleSlides).each(function() {
    $(this).css('opacity', 1);
    console.log($(this).html());
  });
  //Set the opacity of the first and last partial slides.
  $(visibleSlides).first().prev().css('opacity', 0);
  $(visibleSlides).last().next().css('opacity', 0);
}

//Execute the function to apply the visibility on dom ready.
$(setSlideVisibility());

//Re-apply the visibility in the beforeChange event.
$('.slider-nav').on('beforeChange', function() {
  $('.slick-slide').each(function() {
    $(this).css('opacity', 1);
  });
});

//After the slide change has completed, call the setSlideVisibility to hide the partial slides.
$('.slider-nav').on('afterChange', function() {
  setSlideVisibility();
});

<强> Fiddle Demo