Карусель
Компонент слайд-шоу для цикличного повторения элементов - карусель изображения или текстовые слайды.
Как это работает
«Карусель» - это слайд-шоу для отображения серии содержимого, созданная на основе CSS 3D-трансформаций и немного на JS. Она работает с текстом, изображениями или обычной разметкой. Она также поддерживает кнопки “next/prev”.
В браузерах с поддержкой API видимости страниц элементы карусели не будут сменяться, когда страница невидима пользователю (например, когда вкладка браузера неактивна, или окно браузера «минимизировано» - кнопка «квадратик» слева от крестика «закрыть браузер», и т.д.).
Пожалуйста, знайте, что вложенные карусели не поддерживаются, а карусели в целом не очень желательны «стандартам доступности».
В итоге, если вы используете карусели BS4, это требует подключения util.js
.
Пример
Карусель не нормализует автоматически размер содержимого слайдов. Поэтому вам могут понадобиться дополнительные утилиты для придания их содержимому нужного размера. Пока карусели поддерживают кнопки «prev/next», их не надо добавлять явно. Добавьте и настраивайте их самостоятельно.
Задавайте уникальный id классу .carousel
для возможности гибкого управления, особенно если вы используете много каруселей на странице.
Только слайды
Вот пример карусели только со слайдами. Отметим наличие классов .d-block
и .img-fluid
в изображениях карусели – их цель в том, чтобы предотвратить дефолтное выравнивание изображений браузером.
<div id="carouselExampleSlidesOnly" class="carousel slide" data-ride="carousel">
<div class="carousel-inner">
<div class="carousel-item active">
<img class="d-block w-100" src="..." alt="Первый слайд">
</div>
<div class="carousel-item">
<img class="d-block w-100" src="..." alt="Второй слайд">
</div>
<div class="carousel-item">
<img class="d-block w-100" src="..." alt="Третий слайд">
</div>
</div>
</div>
С органами управления
Добавляет кнопки prev/next:
<div id="carouselExampleControls" class="carousel slide" data-ride="carousel">
<div class="carousel-inner">
<div class="carousel-item active">
<img class="d-block w-100" src="..." alt="Первый слайд">
</div>
<div class="carousel-item">
<img class="d-block w-100" src="..." alt="Второй слайд">
</div>
<div class="carousel-item">
<img class="d-block w-100" src="..." alt="Третий слайд">
</div>
</div>
<a class="carousel-control-prev" href="#carouselExampleControls" role="button" data-slide="prev">
<span class="carousel-control-prev-icon" aria-hidden="true"></span>
<span class="sr-only">Previous</span>
</a>
<a class="carousel-control-next" href="#carouselExampleControls" role="button" data-slide="next">
<span class="carousel-control-next-icon" aria-hidden="true"></span>
<span class="sr-only">Next</span>
</a>
</div>
С индикаторами
Вы также можете добавить индикаторы к карусели, наряду с органами управления.
<div id="carouselExampleIndicators" class="carousel slide" data-ride="carousel">
<ol class="carousel-indicators">
<li data-target="#carouselExampleIndicators" data-slide-to="0" class="active"></li>
<li data-target="#carouselExampleIndicators" data-slide-to="1"></li>
<li data-target="#carouselExampleIndicators" data-slide-to="2"></li>
</ol>
<div class="carousel-inner">
<div class="carousel-item active">
<img class="d-block w-100" src="..." alt="Первый слайд">
</div>
<div class="carousel-item">
<img class="d-block w-100" src="..." alt="Второй слайд">
</div>
<div class="carousel-item">
<img class="d-block w-100" src="..." alt="Третий слайд">
</div>
</div>
<a class="carousel-control-prev" href="#carouselExampleIndicators" role="button" data-slide="prev">
<span class="carousel-control-prev-icon" aria-hidden="true"></span>
<span class="sr-only">Previous</span>
</a>
<a class="carousel-control-next" href="#carouselExampleIndicators" role="button" data-slide="next">
<span class="carousel-control-next-icon" aria-hidden="true"></span>
<span class="sr-only">Next</span>
</a>
</div>
Требуется начальный активный элемент
Необходимо добавлять класс .active
в один из слайдов, иначе карусель не будет видна.
С надписями
Добавляйте надписи в ваши слайды с помощью добавления элемента класса .carousel-caption
в любой элемент карусели класса .carousel-item
. Надписи легко скрыть на меньших устройствах, используя утилиты отображения. Они спрятаны первоначально с помощью класса .d-none
и показываем их опять на средних устройствах с помощью класса .d-md-block
.
Использование
Через атрибуты
Атрибут data-slide
принимает значения prev
или next
, которые изменяют позицию слайда относительно его текущей позиции. Или используйте data-slide-to
для перехода на слайд с индексом, например, 2: data-slide-to="2"
, индексы слайдов начинаются с 0
.
Атрибут data-ride="carousel"
используется для создания анимации карусели. Его нельзя сочетать с явной инициализацией карусели через JavaScript.
Через JavaScript
Вызывайте карусель вручную:
Параметры
Параметры можно передавать через атрибуты или JavaScript. Для использования атрибутов добавьте название параметра в data-
, например: data-interval=""
.
Имя | Тип | По умолч. | Описание |
---|---|---|---|
interval | число | 5000 | Время задержки между автоматической сменой слайда. Если false – карусель не будет автоматически сменять слайды. |
keyboard | boolean | true | Будет ли карусель реагировать на события клавиатуры. |
pause | строка | boolean | "hover" |
Если стоит Устройства, активируемые касанием: |
ride | строка | false | Автосмена слайдов карусели после первой ручной смены слайда юзером. Если carousel – автосмена включается после загрузки. |
wrap | boolean | true | Должна ли карусель сменяться плавно или дискретно. |
Методы
Асинхронные методы и переходы
Все методы API асинхронны и запускают переход. Они возвращаются функции, вызвавшей их, с началом перехода, но до его конца. Плюс, вызов метода к компоненту, выполняющему переход, будет проигнорирован.
.carousel(options)
Инициализирует объект object
карусели с установленными параметрами и начинает смену слайдов.
.carousel('cycle')
Сменяет слайды карусели слева направо.
.carousel('pause')
Останавливает смену слайдов.
.carousel(number)
Прокручивает слайды до определенного момента (основано на 0, схоже с рядами). Возвращает значение функции-вызову до того, как элемент-«цель» показан (т.е. до того, как возникает событие slid.bs.carousel
).
.carousel('prev')
Прокручивает к предыдущему слайду. Возвращает значение функции-вызову до того, как элемент-«цель» показан (т.е. до того, как возникает событие slid.bs.carousel
).
.carousel('next')
К следующему слайду. Возвращает значение функции-вызову до того, как элемент-«цель» показан (т.е. до того, как возникает событие slid.bs.carousel
).
.carousel('dispose')
Уничтожает карусель элемента.
События
Карусель в Bootstrap располагает 2-мя событиями для применения функциональности. У обоих событий есть следующие дополнительные свойства:
direction
: Направление, в котором движутся слайды ("left"
или"right"
).relatedTarget
: Элемент DOM, который движется на место «пролистанного» слайда.from
: Индекс текущего слайдаto
: Индекс следующего слайда
Все события карусели запускаются непосредственно в каруселу (т.е. в <div class="carousel">
).
Тип события | Описание |
---|---|
slide.bs.carousel | Это событие запускается немедленно, когда вызван метод slide . |
slid.bs.carousel | Это событие запускается, когда карусель завершила переходы своих слайдов. |