- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在处理this site目前我有一个 Slick Slider它使用 centerMode: true
变量。
我将 slidesToShow
设置为 3,因此当幻灯片数量为 3 或更少时,它无法正确居中。 Here's正确使用 3 张以上幻灯片并居中的示例。
我使用的代码稍微改进了一些东西,但它仍然没有完全正确地居中:
// Set preferred slidesToShow
var slidesToShow = 3;
var childElements = $('.category-gallery').children().length;
// Check if we can fulfill the preferred slidesToShow
if( slidesToShow > (childElements-1) ) {
// Otherwise, make slidesToShow the number of slides - 1
// Has to be -1 otherwise there is nothing to scroll for - all the slides would already be visible
slidesToShow = (childElements-1);
}
$('.category-gallery').slick({
dots: false,
infinite: true,
slidesToShow: slidesToShow,
slidesToScroll: 1,
autoplay: false,
pauseOnHover:false,
focusOnSelect: false,
centerMode:true,
arrows: true,
});
如何强制它正确居中?
发生的情况是这样的,右侧的大图像应该位于中心。
最佳答案
如果你看source对于 Slick.prototype.setupInfinite()
,您会看到以下条件:
if (_.slideCount > _.options.slidesToShow) {
// The slides are cloned here.
}
这意味着,如果幻灯片总数(即 .slide
元素)小于或等于 slidesToShow
选项,幻灯片将不会被克隆,并且centerMode
滚动效果将不会按预期发生。 p>
因此,就 centerMode
滚动效果而言,您的代码确实有效;但是,要获得正确的效果 - 始终可见 3 个项目/幻灯片,并且一次仅滚动一个项目/幻灯片且事件的项目/幻灯片居中,您可以手动克隆幻灯片 (.slide
)如下所示:
var slidesToShow = 3; // always 3
// Clone the slides.
var $slides = $('.category-gallery .slide');
if ($slides.length > 1 && $slides.length <= slidesToShow) {
var $slide;
$slides.each( function(){
$slide = $(this).clone(true)
.insertAfter( $slide || $slides.last() )
.addClass('slick-cloned-2')
.attr('id', '');
});
}
// If the total number of slides is less than 3, we set this to the
// total number of slides - i.e. either 2 or 1. But of course, the
// 3-slides centerMode effect won't happen anymore.
slidesToShow = Math.min(slidesToShow, $slides.length);
$('.category-gallery').slick({
// You can find the full code below on this page.
});
名为 slick-cloned-2
的 CSS class
只是为了区分幻灯片与原始幻灯片。您可以重命名它,但不要使用 slick-cloned
因为 Slick 使用它。或者,如果您不想,就不要添加它..
但是由于我们手动克隆了幻灯片,因此我们需要如下所示调整幻灯片索引,该索引用于突出显示项目过滤器中的幻灯片链接 - 例如this page 上“航空公司”标题下方的链接:
$('.category-gallery').on('afterChange', function(event, slick, currentSlide, nextSlide){
var i = currentSlide >= slidesToShow ? currentSlide - slidesToShow : currentSlide;
...
$('a.category-nav[data-slide=' + (i + 1) + ']').addClass('highlighted-cat-nav');
});
这是我使用的完整代码:
// Category gallery
// Set preferred slidesToShow
var slidesToShow = 3; // always 3
// Clone the slides.
var $slides = $('.category-gallery .slide');
if ($slides.length > 1 && $slides.length <= slidesToShow) {
var $slide;
$slides.each( function(){
$slide = $(this).clone(true)
.insertAfter( $slide || $slides.last() )
.addClass('slick-cloned-2')
.attr('id', '');
});
}
// If the total number of slides is less than 3, we set this to the
// total number of slides - i.e. either 2 or 1. But of course, the
// 3-slides centerMode effect won't happen anymore.
slidesToShow = Math.min(slidesToShow, $slides.length);
$('.category-gallery').slick({
dots: false,
infinite: true,
slidesToShow: slidesToShow,
slidesToScroll: 1,
autoplay: false,
pauseOnHover:false,
focusOnSelect: false,
centerMode:true,
arrows: true,
});
$('a.category-nav[data-slide]').click(function(e) {
e.preventDefault();
var slideno = $(this).data('slide');
$('.category-gallery').slick('slickGoTo', slideno - 1);
});
$('a.category-nav[data-slide="1"]').addClass("highlighted-cat-nav");
$('.category-gallery').on('afterChange', function(event, slick, currentSlide, nextSlide){
var i = currentSlide >= slidesToShow ? currentSlide - slidesToShow : currentSlide;
$('a.category-nav').removeClass('highlighted-cat-nav');
$('a.category-nav[data-slide=' + (i + 1) + ']').addClass('highlighted-cat-nav');
});
<小时/>
您可以尝试的其他选项:
当幻灯片总数为 3
时,在最后一张幻灯片后添加一个空 .slide
元素。然后,例如, Hook beforeChange
Slick 事件,并相应地移动幽灵幻灯片 - 或者更改其 HTML,以便幻灯片显示“正确的”项目。
更改/覆盖 Slick.prototype.setupInfinite()
函数..
但是我建议的克隆方法(并经过尝试和测试)会给您带来最平滑的效果.. 只是,幻灯片/项目被克隆两次 - 由我们/您手动克隆,然后由 Slick 克隆。
关于jquery - 当幻灯片数量多于 Slidestoshow 变量时,光滑 slider 中心模式不起作用,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/52311614/
这个问题已经有答案了: 已关闭11 年前。 Possible Duplicate: How to align a to the middle of the page 这是一个简单的问题,应该有一个简
我想知道如何在屏幕中央的ListView中生成2个itens。 class _CategoriesState extends State { List categories = ["Anterio
我需要修复 UICollectionView 的一个小问题,当在 6s 设备尺寸上时,我得到如下布局: 但是,我想知道将它们居中以使其成为两条线的最佳方法是什么,或者我应该将它们缩小一点以便可以放置其
我尝试在 UIImageView 中居中 CAShapeLayer 但没有成功,我找到了解决方案,将其(CAShapeLayer)添加到 UIVIew,然后将 UIVIew 添加到 ImageView
一直在从线性布局和相对布局切换,因为我想实现图像的居中。 显示图片:
* { margin:0; padding:0; } /** General Style Info **/ body { background: #003d4c; co
我目前正在尝试修改我在 Wordpress 上的 Royal Slider 插件 (http://dimsemenov.com/plugins/royal-slider/) 我的目标是将所有标题的文本
我已经坚持了一段时间,因此简化了我的要求。当您单击标记时,信息窗口将打开,当用户缩放时,我希望该标记位于 map 的中心。这不起作用,但我认为它很接近: function bindInfoWindow
/* Linked Styles */ body { padding: 0 !important;
这个问题在这里已经有了答案: How do I center floated elements? (12 个答案) 关闭 7 年前。
这个问题在这里已经有了答案: Is there an equivalent to background-size: cover and contain for image elements? (1
我试图让我的页眉停留在页面的中间,不管我在什么窗口大小。 我试过使用 Bootstrap。 StackOverflow 还有这个 CSS。 .section-t
我有一个 1600 像素宽的页面。主要区域虽然只有 900 像素宽。我有一个导航应该固定在页面的中心(它是)。我的问题是当我打开页面时,页面固定在左侧而不是在打开时居中。当用户访问该网站时,我需要做什
我正在尝试找到 View 的中心。对于非旋转 View ,该值是正确的,但对于旋转 View ,它不正确,因为中心 (0,0) 正在旋转。在缩放的情况下,即使缩放后宽度和高度也保持不变 我正在使用以下
预期效果是将 Kartennummer 和 Passwort 集中。 这怎么可能? 我为此使用了一个自定义类: import 'package:flutter/material.dart'; impo
我管理着许多 Maven 项目。他们中的大多数部署到我们的内部 maven 存储库。现在我想开始向 Maven Central 发布一个项目。到目前为止,我有一个父 POM,它指定了我们内部存储库的
我试图锚定两个进展,但我看不到获得预期结果的方法。 我希望左边的进度条固定在左边,右边的条固定在中心固定(如下图所示) (下图显示调整大小的表格) 我尝试将控件放在具有各种 anchor 的停靠面板上
我正在玩 Angular 模态 ui 对话框。我想知道有什么方法可以让它居中?我发现了一个类似的问题: Twitter Bootstrap - Center Modal Dialog 但无法使其工作,
是否可以将值标签放置在条形上,使它们位于条形的中心? 如果我设置条形 align: "center",则条形上的标签将关闭且不居中。 $(function() { var d
http://www.asp.net/signalr/overview/signalr-20/getting-started-with-signalr-20/tutorial-signalr-20-s
我是一名优秀的程序员,十分优秀!