我正在尝试实现迄今为止尚未在网络上实现的目标。我希望滑动滑块中的活动分页点始终位于中心。
这是预期的结果:
换句话说,我希望页面加载后显示第一张幻灯片,但第一张幻灯片的分页点应居中。
如果用户通过滑动来单击下一张幻灯片,则该点应再次在中间移动,并且活动幻灯片始终在分页中居中。关于实现此目标的最佳方法的任何想法?
这是到目前为止我所做的示例和代码。
$('.slider').slick({
infinite: true,
dots: true,
arrows: false
});
.slider {
width: 200px;
}
.slide img {
display: block;
width: 100%;
height: auto;
}
.slick-dots {
display: flex;
justify-content: center;
margin: 0;
padding: 1rem 0;
list-style-type: none;
}
.slick-dots li {
margin: 0 0.25rem;
}
.slick-dots button {
display: block;
width: 1rem;
height: 1rem;
padding: 0;
border: none;
border-radius: 100%;
background-color: grey;
text-indent: -9999px;
}
.slick-dots li.slick-active button {
background-color: blue;
}
<script src="https://code.jquery.com/jquery-3.3.1.slim.min.js" integrity="sha256-3edrmyuQ0w65f8gfBsqowzjJe2iM6n0nKciPUp8y+7E=" crossorigin="anonymous"></script>
<script type="text/javascript" src="//cdn.jsdelivr.net/npm/slick-carousel@1.8.1/slick/slick.min.js"></script>
<link rel="stylesheet" type="text/css" href="//cdn.jsdelivr.net/npm/slick-carousel@1.8.1/slick/slick.css" />
<div class="slider">
<div class="slide">
<img src="http://placehold.it/200x100?text=1" />
</div>
<div class="slide">
<img src="http://placehold.it/200x100?text=2" />
</div>
<div class="slide">
<img src="http://placehold.it/200x100?text=3" />
</div>
<div class="slide">
<img src="http://placehold.it/200x100?text=4" />
</div>
<div class="slide">
<img src="http://placehold.it/200x100?text=5" />
</div>
</div>
答案 0 :(得分:7)
为此,您必须按照我的代码片段再添加一个滑块,并使用“滑块同步”功能来绑定两个滑块。
这是一个可行的例子
$(document).ready(function() {
$(".main_slider").slick({
infinite: true,
dots: false,
arrows: false,
asNavFor: '.slider_dots',
slidesToShow: 1,
slidesToScroll: 1,
});
$('.slider_dots').slick({
infinite: true,
slidesToShow: 3,
slidesToScroll: 1,
asNavFor: '.main_slider',
arrows: false,
dots: false,
centerMode: true,
focusOnSelect: true,
centerPadding: '20%',
});
});
.main_slider,
.slider_dots {
width: 200px;
}
.slide img {
display: block;
width: 100%;
height: auto;
}
.slick-dots {
display: flex;
justify-content: center;
margin: 0;
padding: 1rem 0;
list-style-type: none;
}
.slick-dots li {
margin: 0 0.25rem;
}
.slick-dots button {
display: block;
width: 1rem;
height: 1rem;
padding: 0;
border: none;
border-radius: 100%;
background-color: grey;
text-indent: -9999px;
}
.slick-dots li.slick-active button {
background-color: blue;
}
.slider_dots .slider_navigators {
height: 20px;
background-color: #9E9E9E;
border-radius: 50%;
margin: 10px;
transform: scale(0.4);
outline: none;
cursor: pointer;
}
.slider_dots .slider_navigators.slick-active {
transform: scale(0.70);
}
.slider_navigators.slick-active.slick-current {
transform: scale(1);
background-color: #00f;
}
<!DOCTYPE html>
<html>
<head>
<title>Demo Page</title>
<meta charset="utf-8">
<meta name="viewport" content="width=device-width, initial-scale=1">
<link rel="stylesheet" type="text/css" href="https://cdn.jsdelivr.net/npm/slick-carousel@1.8.1/slick/slick.css" />
<script src="https://ajax.googleapis.com/ajax/libs/jquery/3.4.1/jquery.min.js"></script>
<script type="text/javascript" src="https://cdn.jsdelivr.net/npm/slick-carousel@1.8.1/slick/slick.min.js"></script>
</head>
<body>
<div class="main_slider">
<div class="slide">
<img src="http://placehold.it/200x100?text=1" />
</div>
<div class="slide">
<img src="http://placehold.it/200x100?text=2" />
</div>
<div class="slide">
<img src="http://placehold.it/200x100?text=3" />
</div>
<div class="slide">
<img src="http://placehold.it/200x100?text=4" />
</div>
<div class="slide">
<img src="http://placehold.it/200x100?text=5" />
</div>
<div class="slide">
<img src="http://placehold.it/200x100?text=6" />
</div>
<div class="slide">
<img src="http://placehold.it/200x100?text=7" />
</div>
<div class="slide">
<img src="http://placehold.it/200x100?text=8" />
</div>
<div class="slide">
<img src="http://placehold.it/200x100?text=9" />
</div>
<div class="slide">
<img src="http://placehold.it/200x100?text=10" />
</div>
</div>
<div class="slider_dots">
<div class="slider_navigators"></div>
<div class="slider_navigators"></div>
<div class="slider_navigators"></div>
<div class="slider_navigators"></div>
<div class="slider_navigators"></div>
<div class="slider_navigators"></div>
<div class="slider_navigators"></div>
<div class="slider_navigators"></div>
<div class="slider_navigators"></div>
<div class="slider_navigators"></div>
</div>
</body>
</html>
希望您能从我的代码段中获得解决方案。
答案 1 :(得分:2)
这里是一个示例,该示例使用一些jQuery来操纵现有滑点的样式。可以在此处找到工作代码的另一个示例:https://codepen.io/edlucas/pen/XWJRmbb
唯一的警告是,包含点的<li>
标签必须全部具有相同的宽度才能计算出数学值。此解决方案可以在一行中使用任意数量的点。
const $slideShow = $('.slider');
function offsetDots(slideNum) {
const $slickDots = $slideShow.find('.slick-dots'),
numDots = $slickDots.find('li').length,
dotWidth = $slickDots.find('li:first').outerWidth(true),
offset = dotWidth * slideNum;
// Offset the dots container to center current slide dot
$slickDots.css('marginLeft', offset * -1 - Math.ceil(dotWidth / 2));
// Clear existing secondary dot class
$slickDots.find('li').removeClass('slick-secondary');
// Add secondary dot class to preceeding slide dot
if (slideNum > 0) {
$slickDots.find('li:nth-of-type('+slideNum+')').addClass('slick-secondary');
}
// Add secondary dot class to next slide dot
if (slideNum < numDots - 1) {
$slickDots.find('li:nth-of-type('+(slideNum + 2)+')').addClass('slick-secondary');
}
}
$slideShow.on('init', function(event, slick) {
offsetDots(0);
});
$slideShow.on('beforeChange', function(event, slick, currentSlide, nextSlide) {
offsetDots(nextSlide);
});
$slideShow.slick({
infinite: true,
dots: true,
arrows: false
});
.demo-wrapper{
width: 200px;
position: relative;
}
.slide img {
display: block;
width: 100%;
height: auto;
}
.slick-dots {
position: absolute;
left: 50%;
display: inline-flex;
margin: 0;
padding: 1rem 0;
list-style-type: none;
}
.slick-dots li {
width: 12px;
margin: 0 3px;
}
.slick-dots button {
display: block;
width: 6px;
height: 6px;
padding: 0;
margin: 0 auto;
border: none;
border-radius: 100%;
background-color: grey;
text-indent: -9999px;
}
.slick-dots li.slick-active button {
background-color: blue;
width: 12px;
height: 12px;
margin-top:-4px
}
.slick-dots li.slick-secondary button {
width: 8px;
height: 8px;
margin-top: -1px;
}
<script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/3.3.1/jquery.min.js"></script>
<script type="text/javascript" src="//cdn.jsdelivr.net/npm/slick-carousel@1.8.1/slick/slick.min.js"></script>
<link rel="stylesheet" type="text/css" href="//cdn.jsdelivr.net/npm/slick-carousel@1.8.1/slick/slick.css" />
<div class="demo-wrapper">
<div class="slider">
<div class="slide">
<img src="https://loremflickr.com/200/200/lego?random=1" />
</div>
<div class="slide">
<img src="https://loremflickr.com/200/200/lego?random=2" />
</div>
<div class="slide">
<img src="https://loremflickr.com/200/200/lego?random=3" />
</div>
<div class="slide">
<img src="https://loremflickr.com/200/200/lego?random=4" />
</div>
<div class="slide">
<img src="https://loremflickr.com/200/200/lego?random=5" />
</div>
</div>
</div>
答案 2 :(得分:0)
.on('beforeChange', function(event, slick, currentSlide, nextSlide){
//appedn the bullet on center
});
类似这样的东西
答案 3 :(得分:0)
如果您需要正确实现此目标,则可以尝试 Abhishek Pandey 解决方案。
如果您只需要快速解决问题,则可以尝试类似 使滑块从幻灯片3而不是幻灯片1开始
由于您的滑块导航只是没有数字的点,因此网站用户不会认识到滑块是从幻灯片3开始的