#javascript #swiper #swiper.js
#javascript #swiper.js
Вопрос:
Я хочу показать часть второго слайда в поле зрения. Около 20-30%. Я установил для slidesPerView значение 2.1 (на мобильных устройствах!), чтобы показывать часть следующего слайда. Однако при прокрутке слайдов он не привязывается к началу контейнера, что приводит к тому, что части слайдов не отображаются при прокрутке swiper.
Я попытался установить высоту слайда на 70%, но это приводит к той же проблеме. Я также возился с параметром slidesOffsetAfter, но безуспешно.
- Слайд-шоу привязывается к началу контейнера, показывая изображение целиком
- Следующий слайд должен быть частично виден
Чтобы увидеть текущее состояние проекта: живая среда разработки
Вы можете увидеть проблему на рабочем столе в горизонтальном режиме прокрутки и на планшете в вертикальном режиме прокрутки.
CSS
<!-- swiper CSS -->
<link rel="stylesheet" href="https://unpkg.com/swiper/swiper-bundle.min.css">
<style>
@media screen and (max-width: 1079px){
.swiper-section {
justify-content: flex-start;
margin-top: 194px;
}
}
@media screen and (max-width: 1079px){
.main-navigation {
left: 45px;
top: 45px;
}
}
@media screen and (max-width: 1079px){
.sub-navigation {
right: 45px;
top: 45px;
}
}
@media screen and (max-width: 1079px){
.swiper-container {
height: 965px;
}
}
.swiper-slide {
padding-bottom: 45px;
}
@media screen and (max-width: 1079px) {
.swiper-slide {
padding-bottom: 0px;
}
}
.swiper-slide:nth-child(even) {
height: 75%;
width: 45vw !important;
}
.swiper-slide:nth-child(odd) {
height: 100%;
width: 55vw !important;
}
@media screen and (max-width: 1079px) {
.swiper-div {
margin: 0px 45px 0px 45px;
}
}
@media screen and (max-width: 1079px) {
.swiper-slide:nth-child(even) {
height: 100%!important;
width: 100% !important;
}
}
@media screen and (max-width: 1079px) {
.swiper-slide:nth-child(odd) {
height: 100%!important;
width: 100% !important;
}
}
.swiper-slide>img {
object-fit: cover;
width: 100%;
height: 100%;
}
.swiper-button-prev,
.swiper-button-next {
display: none;
}
.swiper-container-horizontal>.swiper-pagination-progressbar {
width: 175px;
margin-left: 65px;
border-radius: 50px;
}
.swiper-pagination-progressbar {
margin-top: 733px;
background: #bababa;
}
.swiper-pagination-progressbar .swiper-pagination-progressbar-fill {
background: #888888;
}
.swiper-container-horizontal>.swiper-pagination-progressbar {
height: 12px;
}
.swiper-container-vertical>.swiper-pagination-progressbar {
display: none;
}
</style>
JS
<!-- swiper JS -->
<script src="https://unpkg.com/swiper/swiper-bundle.min.js"></script>
<!-- Swiper - Extra Step - add arrows and pagination html markup by code (Append) -->
<script>
var swiperNodes = "";
var pagination = '<div class=swiper-pagination></div>';
var next_prev_buttons = '<div class="swiper-button-prev"></div><div class="swiper-button-next"></div>';
var scrollbar = '<div class="swiper-scrollbar"></div>';
var swiperNodes = swiperNodes.concat(pagination, next_prev_buttons);
/* loop throw all swipers on the page */
$('.swiper-container').each(function( index ) {
$( this ).append(swiperNodes);
});
</script>
<!-- swiper JS Initialize -->
<script>
var mySwiper = new Swiper ('.swiper-container', {
// Optional parameters
slidesPerView: 1,
spaceBetween: 30,
freeMode: false,
loop: true,
centeredSlides: false,
// Enable lazy loading
lazy: true,
mousewheel: {
invert: true,
},
keyboard: {
enabled: true,
onlyInViewport: false,
},
scrollbar: {
el: '.swiper-scrollbar',
draggable: true,
},
navigation: {
nextEl: '.swiper-button-next',
prevEl: '.swiper-button-prev',
},
pagination: {
el: '.swiper-pagination',
type: 'progressbar',
},
keyboard: {
enabled: true,
},
breakpoints: {
0: { /* when window >=0px - webflow mobile landscape/portriat */
slidesPerView: 1,
spaceBetween: 10,
slidesOffsetBefore: 0,
direction: 'vertical',
},
767: { /* when window >= 767px - webflow tablet */
slidesPerView: 2.1,
spaceBetween: 30,
slidesOffsetBefore: 0,
direction: 'vertical',
},
1279: { /* when window >= 988px - webflow desktop */
slidesPerView: 2,
spaceBetween: 20,
slidesOffsetBefore: 0,
}
},
/* uncomment if you want autoplay slider
autoplay: {
delay: 3000,
},
*/
/* uncomment if you want scrollbar
scrollbar: {
el: '.swiper-scrollbar',
hide: true,
},
*/
})
</script>
Комментарии:
1. Следуйте этому примеру (установите ширину на авто и сдвиньте, например, до 80% — не используйте 2.1): swiperjs.com/demos/#auto_slides_per_view_carousel_mode
Ответ №1:
вы можете изменить slidesPerView
значение числа с плавающей точкой, например 1.5, и если вы установите необязательный параметр на centeredSlides: true,loop: true
, вы сможете мало видеть как предыдущий, так и следующий слайдер
Комментарии:
1. Я использую swiper годами, но я никогда не думал, что можно просто использовать число с плавающей точкой. Спасибо Вам, сэр!
Ответ №2:
На этом слайде будет показан частичный вид следующего и предыдущего слайдов. В моем случае это карусель во всю ширину, поэтому я использую vw
в CSS, но вы можете использовать пиксели или %
const swiper = new Swiper( selector, {
slidesPerView: 'auto',
centeredSlides: true,
loop: true,
slidesPerGroup: 1,
paginationClickable: true,
pagination: {
el: '.swiper-pagination',
clickable: true,
},
} );
И CSS:
.swiper-slide {
width: 80vw;
}
Комментарии:
1. Если я хочу показать второй слайд с помощью show slide 1 и 3, покажите несколько частей. Как это сделать?
Ответ №3:
Мне удалось показать только часть следующего слайда, создав div
внешний div.swiper-container
элемент и оформив внутренний div
с padding
помощью, что может создать желаемый эффект.
Если вы хотите показать только предварительный просмотр следующего, оформите только отступ справа или отступ слева, и все будет готово.
Применяемое заполнение должно учитывать пробелы между контейнерами. В моем случае spaceBetween
было 10, поэтому я использовал 20 пикселей в качестве отступа.
Вот некоторый псевдокод:
<script>
const swiper = new Swiper( '.my-class', {
slidesPerView: 2,
spaceBetween: 10,
slidesPerGroup: 2,
centeredSlides: false,
loop: true,
paginationClickable: true,
pagination: {
el: '.swiper-pagination',
clickable: true,
},
} );
</script>
<style>
.full-width {
margin: 0 calc(-100vw / 2 100% / 2) !important;
width: 100vw;
}
.my-class {
padding: 20px;
}
</style>
<div class="full-width">
<div class="swiper-container my-class">
...
</div>
<div>
Ответ №4:
вот мой опыт:
я хочу, чтобы 5 элементов слайда,
начальный элемент и конечный элемент отображались в идеальном половинном размере.
$_offset_x: размер каждого элемента в два раза меньше, я использую процент в соответствии с дизайном.
.swiper-wrapper {
// left: $_offset_x!important;
left: 9.63%!important;
}
используйте медиа-запрос, если у вас есть дополнительная потребность в мобильных устройствах.
Ответ №5:
Если вы хотите показать 1 слайд полностью, а 2 слайд наполовину, вы можете использовать конфигурацию, подобную
Просмотр слайдов: 1.2, работает в swiper версии 8.3