Карусель
Компонент слайд-шоу для цикличного повторения элементов - карусель изображений или текстовых слайдов.
Как это работает
«Карусель» - это слайд-шоу для отображения серии содержимого, созданная на основе CSS 3D-трансформаций и немного на JavaScript. Она работает с текстом, изображениями или обычной разметкой. Она также поддерживает кнопки “next/prev”.
В браузерах с поддержкой API видимости страниц элементы карусели не будут сменяться, когда страница невидима пользователю (например, когда вкладка браузера неактивна, или окно браузера «минимизировано» - кнопка «квадратик» слева от крестика «закрыть браузер», и т.д.).
prefers-reduced-motion. Смотрите раздел о редукции анимаций.
Учтите, что вложенные карусели не поддерживаются, а карусели в целом не очень желательны «стандартам доступности».
Пример
Карусель не подстраивает автоматически размер содержимого слайдов. Поэтому вам могут понадобиться дополнительные утилиты для придания их содержимому нужного размера. Пока карусели поддерживают кнопки «prev/next», их не надо добавлять явно. Добавьте и настраивайте их самостоятельно.
Класс .active добавляют к одному из слайдов, иначе карусель не будет видно. Также для внедрения элементов управления необходимо задать уникальный ID элементу класса .carousel, особенно если у вас много каруселей на одной странице. Элементы управления и индикаторы должны иметь атрибут data-target (или href для <a>), который совпадает с ID элемента класса .carousel.
Задавайте уникальный id классу .carousel для возможности гибкого управления, особенно если вы используете много каруселей на странице.
Только слайды
Вот пример карусели, где есть только слайды. Заметьте присутствие классов .d-block и .w-100, отменяющих дефолтное выравнивание изображений в браузерах у изображений карусели.
<divid="carouselExampleSlidesOnly"class="carousel slide"data-bs-ride="carousel"><divclass="carousel-inner"><divclass="carousel-item active"><imgsrc="..."class="d-block w-100"alt="..."></div><divclass="carousel-item"><imgsrc="..."class="d-block w-100"alt="..."></div><divclass="carousel-item"><imgsrc="..."class="d-block w-100"alt="..."></div></div></div>С элементами управления
Добавляет кнопки prev/next:
<divid="carouselExampleControls"class="carousel slide"data-bs-ride="carousel"><divclass="carousel-inner"><divclass="carousel-item active"><imgsrc="..."class="d-block w-100"alt="..."></div><divclass="carousel-item"><imgsrc="..."class="d-block w-100"alt="..."></div><divclass="carousel-item"><imgsrc="..."class="d-block w-100"alt="..."></div></div><buttonclass="carousel-control-prev"type="button"data-bs-target="#carouselExampleControls"data-bs-slide="prev"><spanclass="carousel-control-prev-icon"aria-hidden="true"></span><spanclass="visually-hidden">Предыдущий</span></button><buttonclass="carousel-control-next"type="button"data-bs-target="#carouselExampleControls"data-bs-slide="next"><spanclass="carousel-control-next-icon"aria-hidden="true"></span><spanclass="visually-hidden">Следующий</span></button></div>С индикаторами
Вы также можете добавить индикаторы к карусели, наряду с органами управления.
<divid="carouselExampleIndicators"class="carousel slide"data-bs-ride="carousel"><divclass="carousel-indicators"><buttontype="button"data-bs-target="#carouselExampleIndicators"data-bs-slide-to="0"class="active"aria-current="true"aria-label="Slide 1"></button><buttontype="button"data-bs-target="#carouselExampleIndicators"data-bs-slide-to="1"aria-label="Slide 2"></button><buttontype="button"data-bs-target="#carouselExampleIndicators"data-bs-slide-to="2"aria-label="Slide 3"></button></div><divclass="carousel-inner"><divclass="carousel-item active"><imgsrc="..."class="d-block w-100"alt="..."></div><divclass="carousel-item"><imgsrc="..."class="d-block w-100"alt="..."></div><divclass="carousel-item"><imgsrc="..."class="d-block w-100"alt="..."></div></div><buttonclass="carousel-control-prev"type="button"data-bs-target="#carouselExampleIndicators"data-bs-slide="prev"><spanclass="carousel-control-prev-icon"aria-hidden="true"></span><spanclass="visually-hidden">Предыдущий</span></button><buttonclass="carousel-control-next"type="button"data-bs-target="#carouselExampleIndicators"data-bs-slide="next"><spanclass="carousel-control-next-icon"aria-hidden="true"></span><spanclass="visually-hidden">Следующий</span></button></div>С надписями
Добавляйте надписи в ваши слайды с помощью добавления элемента класса .carousel-caption в любой элемент карусели класса .carousel-item. Надписи легко скрыть на меньших устройствах, используя утилиты отображения элементов. Они спрятаны первоначально с помощью класса .d-none и показываем их опять на средних устройствах с помощью класса .d-md-block.
<divid="carouselExampleCaptions"class="carousel slide"data-bs-ride="carousel"><divclass="carousel-indicators"><buttontype="button"data-bs-target="#carouselExampleCaptions"data-bs-slide-to="0"class="active"aria-current="true"aria-label="Slide 1"></button><buttontype="button"data-bs-target="#carouselExampleCaptions"data-bs-slide-to="1"aria-label="Slide 2"></button><buttontype="button"data-bs-target="#carouselExampleCaptions"data-bs-slide-to="2"aria-label="Slide 3"></button></div><divclass="carousel-inner"><divclass="carousel-item active"><imgsrc="..."class="d-block w-100"alt="..."><divclass="carousel-caption d-none d-md-block"><h5>Метка первого слайда</h5><p>Некоторый репрезентативный заполнитель для первого слайда.</p></div></div><divclass="carousel-item"><imgsrc="..."class="d-block w-100"alt="..."><divclass="carousel-caption d-none d-md-block"><h5>Метка второго слайда</h5><p>Некоторый репрезентативный заполнитель для второго слайда.</p></div></div><divclass="carousel-item"><imgsrc="..."class="d-block w-100"alt="..."><divclass="carousel-caption d-none d-md-block"><h5>Метка третьего слайда</h5><p>Некоторый репрезентативный заполнитель для третьего слайда.</p></div></div></div><buttonclass="carousel-control-prev"type="button"data-bs-target="#carouselExampleCaptions"data-bs-slide="prev"><spanclass="carousel-control-prev-icon"aria-hidden="true"></span><spanclass="visually-hidden">Предыдущий</span></button><buttonclass="carousel-control-next"type="button"data-bs-target="#carouselExampleCaptions"data-bs-slide="next"><spanclass="carousel-control-next-icon"aria-hidden="true"></span><spanclass="visually-hidden">Следующий</span></button></div>Склейка (плавный переход)
Добавьте .carousel-fade в вашу карусель для анимации слайдов с постепенным переходом на следующий слайд.
<divid="carouselExampleFade"class="carousel slide carousel-fade"data-bs-ride="carousel"><divclass="carousel-inner"><divclass="carousel-item active"><imgsrc="..."class="d-block w-100"alt="..."></div><divclass="carousel-item"><imgsrc="..."class="d-block w-100"alt="..."></div><divclass="carousel-item"><imgsrc="..."class="d-block w-100"alt="..."></div></div><buttonclass="carousel-control-prev"type="button"data-bs-target="#carouselExampleFade"data-bs-slide="prev"><spanclass="carousel-control-prev-icon"aria-hidden="true"></span><spanclass="visually-hidden">Предыдущий</span></button><buttonclass="carousel-control-next"type="button"data-bs-target="#carouselExampleFade"data-bs-slide="next"><spanclass="carousel-control-next-icon"aria-hidden="true"></span><spanclass="visually-hidden">Следующий</span></button></div>Индивидуальный интервал .carousel-item
Добавьте data-interval="" к элементу .carousel-item, чтобы изменить время задержки между автоматическим циклическим переходом к следующему элементу.
<divid="carouselExampleInterval"class="carousel slide"data-bs-ride="carousel"><divclass="carousel-inner"><divclass="carousel-item active"data-bs-interval="10000"><imgsrc="..."class="d-block w-100"alt="..."></div><divclass="carousel-item"data-bs-interval="2000"><imgsrc="..."class="d-block w-100"alt="..."></div><divclass="carousel-item"><imgsrc="..."class="d-block w-100"alt="..."></div></div><buttonclass="carousel-control-prev"type="button"data-bs-target="#carouselExampleInterval"data-bs-slide="prev"><spanclass="carousel-control-prev-icon"aria-hidden="true"></span><spanclass="visually-hidden">Предыдущий</span></button><buttonclass="carousel-control-next"type="button"data-bs-target="#carouselExampleInterval"data-bs-slide="next"><spanclass="carousel-control-next-icon"aria-hidden="true"></span><spanclass="visually-hidden">Следующий</span></button></div>Отключенный сенсорный свайпинг
Карусели поддерживают смахивание влево/вправо на устройствах с сенсорным экраном для перемещения между слайдами. Это можно отключить с помощью атрибута data-bs-touch. Пример ниже также не включает атрибут data-bs-ride и имеет data-bs-interval="false", поэтому он не запускается автоматически.
<divid="carouselExampleControlsNoTouching"class="carousel slide"data-bs-touch="false"data-bs-interval="false"><divclass="carousel-inner"><divclass="carousel-item active"><imgsrc="..."class="d-block w-100"alt="..."></div><divclass="carousel-item"><imgsrc="..."class="d-block w-100"alt="..."></div><divclass="carousel-item"><imgsrc="..."class="d-block w-100"alt="..."></div></div><buttonclass="carousel-control-prev"type="button"data-bs-target="#carouselExampleControlsNoTouching"data-bs-slide="prev"><spanclass="carousel-control-prev-icon"aria-hidden="true"></span><spanclass="visually-hidden">Предыдущий</span></button><buttonclass="carousel-control-next"type="button"data-bs-target="#carouselExampleControlsNoTouching"data-bs-slide="next"><spanclass="carousel-control-next-icon"aria-hidden="true"></span><spanclass="visually-hidden">Следующий</span></button></div>Темный вариант
Добавьте .carousel-dark к .carousel для отображения более темных элементов управления, индикаторов и подписей. По умолчанию элементы управления инвертированы и смотрятся более темными по сравнению с их белой заливкой благодаря свойству CSS filter. Заголовки и элементы управления имеют дополнительные Sass переменные, которые настраивают цвет color и цвет фона background-color.
<divid="carouselExampleDark"class="carousel carousel-dark slide"data-bs-ride="carousel"><divclass="carousel-indicators"><buttontype="button"data-bs-target="#carouselExampleDark"data-bs-slide-to="0"class="active"aria-current="true"aria-label="Slide 1"></button><buttontype="button"data-bs-target="#carouselExampleDark"data-bs-slide-to="1"aria-label="Slide 2"></button><buttontype="button"data-bs-target="#carouselExampleDark"data-bs-slide-to="2"aria-label="Slide 3"></button></div><divclass="carousel-inner"><divclass="carousel-item active"data-bs-interval="10000"><imgsrc="..."class="d-block w-100"alt="..."><divclass="carousel-caption d-none d-md-block"><h5>Метка первого слайда</h5><p>Некоторый репрезентативный заполнитель для первого слайда.</p></div></div><divclass="carousel-item"data-bs-interval="2000"><imgsrc="..."class="d-block w-100"alt="..."><divclass="carousel-caption d-none d-md-block"><h5>Метка второго слайда</h5><p>Некоторый репрезентативный заполнитель для второго слайда.</p></div></div><divclass="carousel-item"><imgsrc="..."class="d-block w-100"alt="..."><divclass="carousel-caption d-none d-md-block"><h5>Метка третьего слайда</h5><p>Некоторый репрезентативный заполнитель для третьего слайда.</p></div></div></div><buttonclass="carousel-control-prev"type="button"data-bs-target="#carouselExampleDark"data-bs-slide="prev"><spanclass="carousel-control-prev-icon"aria-hidden="true"></span><spanclass="visually-hidden">Предыдущий</span></button><buttonclass="carousel-control-next"type="button"data-bs-target="#carouselExampleDark"data-bs-slide="next"><spanclass="carousel-control-next-icon"aria-hidden="true"></span><spanclass="visually-hidden">Следующий</span></button></div>Изменение продолжительности перехода
Длительность перехода .carousel-item может быть изменена с помощью переменной Sass $carousel-transition-duration перед компиляцией или настраиваемыми стилями, если вы используете скомпилированный CSS. Если применяется несколько переходов, убедитесь, что сначала определен переход преобразования (например, transition: transform 2s ease, opacity .5s ease-out).
Sass
Переменные
$carousel-control-color:$white;$carousel-control-width:15%;$carousel-control-opacity:.5;$carousel-control-hover-opacity:.9;$carousel-control-transition:opacity.15sease;$carousel-indicator-width:30px;$carousel-indicator-height:3px;$carousel-indicator-hit-area-height:10px;$carousel-indicator-spacer:3px;$carousel-indicator-opacity:.5;$carousel-indicator-active-bg:$white;$carousel-indicator-active-opacity:1;$carousel-indicator-transition:opacity.6sease;$carousel-caption-width:70%;$carousel-caption-color:$white;$carousel-caption-padding-y:1.25rem;$carousel-caption-spacer:1.25rem;$carousel-control-icon-width:2rem;$carousel-control-prev-icon-bg:url("data:image/svg+xml,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16' fill='#{$carousel-control-color}'><path d='M11.354 1.646a.5.5 0 0 1 0 .708L5.707 8l5.647 5.646a.5.5 0 0 1-.708.708l-6-6a.5.5 0 0 1 0-.708l6-6a.5.5 0 0 1 .708 0z'/></svg>");$carousel-control-next-icon-bg:url("data:image/svg+xml,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16' fill='#{$carousel-control-color}'><path d='M4.646 1.646a.5.5 0 0 1 .708 0l6 6a.5.5 0 0 1 0 .708l-6 6a.5.5 0 0 1-.708-.708L10.293 8 4.646 2.354a.5.5 0 0 1 0-.708z'/></svg>");$carousel-transition-duration:.6s;$carousel-transition:transform$carousel-transition-durationease-in-out;// Define transform transition first if using multiple transitions (e.g., `transform 2s ease, opacity .5s ease-out`)
$carousel-dark-indicator-active-bg:$black;$carousel-dark-caption-color:$black;$carousel-dark-control-icon-filter:invert(1)grayscale(100);Использование
Через атрибуты
Используйте атрибуты данных, чтобы легко контролировать положение карусели. data-bs-slide принимает ключевые слова prev или next, которые изменяют положение слайда относительно его текущего положения. В качестве альтернативы, используйте data-bs-slide-to, чтобы передать необработанный индекс слайда в карусель data-bs-slide-to="2", который сдвигает положение слайда на конкретный индекс, начинающийся с 0.
Атрибут data-bs-ride="carousel" используется для пометки карусели как анимированной, начиная с загрузки страницы. Если Вы не используете data-bs-ride="carousel" для инициализации карусели, Вам придется инициализировать ее самостоятельно. Его нельзя использовать в сочетании с (избыточной и ненужной) явной инициализацией JavaScript той же карусели.
Через JavaScript
Вызов карусели вручную с помощью:
varmyCarousel=document.querySelector('#myCarousel')varcarousel=newbootstrap.Carousel(myCarousel)Параметры
Параметры можно передавать через атрибуты данных или JavaScript. Для атрибутов данных добавьте имя параметра к data-bs-, как в data-bs-interval="".
| Наименование | Тип | По умолчанию | Описание |
|---|---|---|---|
interval | number | 5000 | Время задержки между автоматическим циклическим переключением элемента. Если false, карусель не будет автоматически повторяться. |
keyboard | boolean | true | Должна ли карусель реагировать на события клавиатуры. |
pause | string | boolean | 'hover' | Если задано значение На устройствах с сенсорным экраном, когда установлено значение |
ride | string | boolean | false | Автоматически отображает карусель после того, как пользователь вручную перебирает первый элемент. Если установлено значение 'carousel', карусель автоматически отображается при загрузке. |
wrap | boolean | true | Должна ли карусель работать непрерывно или иметь жесткие остановки. |
touch | boolean | true | Должна ли карусель поддерживать взаимодействие смахивания влево/вправо на устройствах с сенсорным экраном. |
Методы
Асинхронные методы и переходы
Все методы API асинхронны и запускают переход. Они возвращаются функции, вызвавшей их, с началом перехода, но до его конца. Плюс, вызов метода к компоненту, выполняющему переход, будет проигнорирован.
Вы можете создать экземпляр карусели с помощью конструктора карусели, например, для инициализации с дополнительными параметрами и начала циклического перебора элементов:
varmyCarousel=document.querySelector('#myCarousel')varcarousel=newbootstrap.Carousel(myCarousel,{interval:2000,wrap:false})| Метод | Описание |
|---|---|
cycle | Перебирает элементы карусели слева направо. |
pause | Не дает карусели перебирать элементы. |
prev | Переходит к предыдущему элементу. Возврат к вызывающему абоненту до того, как был показан предыдущий элемент (например, до возникновения события slid.bs.carousel). |
next | Переход к следующему элементу. Возврат к вызывающему абоненту до того, как будет показан следующий элемент (например, до того, как произойдет событие slid.bs.carousel). |
nextWhenVisible | Не переключать карусель на следующую, если страница не отображается или карусель или ее родительский элемент не видны. Возврат к вызывающему абоненту до того, как будет показан целевой элемент |
to | Циклически переключает карусель на конкретный кадр (на основе 0, аналогично массиву). Возврат к вызывающему абоненту до того, как будет показан целевой элемент (например, до того, как произойдет событие slid.bs.carousel). |
dispose | Уничтожает элемент карусели. (Удаляет сохраненные данные в элементе DOM) |
getInstance | Статический метод, который позволяет вам получить экземпляр карусели, связанный с элементом DOM, вы можете использовать его следующим образом: bootstrap.Carousel.getInstance(element) |
getOrCreateInstance | Статический метод, который возвращает экземпляр карусели, связанный с элементом DOM, или создает новый, если он не был инициализирован. Вы можете использовать его так: bootstrap.Carousel.getOrCreateInstance(element) |
События
Класс карусели Bootstrap предоставляет два события для подключения к функциональности карусели. Оба события имеют следующие дополнительные свойства:
direction: Направление, в котором движется карусель ("left"или"right").relatedTarget: Элемент DOM, который вставляется на место как активный элемент.from: Индекс текущего элементаto: Индекс следующего элемента
Все события карусели запускаются в самой карусели (т.е. в <div class="carousel">).
| Тип события | Описание |
|---|---|
slide.bs.carousel | Это событие запускается немедленно, когда вызван метод slide. |
slid.bs.carousel | Это событие запускается, когда карусель завершила переходы своих слайдов. |
varmyCarousel=document.getElementById('myCarousel')myCarousel.addEventListener('slide.bs.carousel',function(){// do something...
})