Un componente de presentación de diapositivas para recorrer elementos (imágenes o diapositivas de texto) como un carrusel.
Cómo funciona el componente Carrusel
El carrusel es una presentación de diapositivas para recorrer una serie de contenido, creada con transformaciones CSS 3D y un poco de JavaScript. Funciona con una serie de imágenes, texto o marcas personalizadas. También incluye soporte para controles e indicadores anteriores/siguientes.
Por razones de rendimiento, los carruseles deben inicializarse manualmente usando el método constructor de carrusel. Sin inicialización, algunos de los detectores de eventos (específicamente, los eventos que necesitan soporte táctil/deslizante) no se registrarán hasta que un usuario haya activado explícitamente un control o indicador.
La única excepción son los carruseles de reproducción automática con el atributo data-bs-ride="carousel" ya que se inicializan automáticamente al cargar la página. Si utilizas carruseles de reproducción automática con el atributo de datos, no inicialices explícitamente los mismos carruseles con el método constructor.
Los carruseles anidados no son compatibles. También debes tener en cuenta que los carruseles en general a menudo pueden causar problemas de usabilidad y accesibilidad.
Ejemplos básicos del componente Carrusel
Aquí tienes un ejemplo básico de un carrusel con tres diapositivas. Ten en cuenta los controles anteriores/siguientes. Recomendamos usar elementos <button>, pero también puedes usar elementos <a> con role="button".
Los carruseles no normalizan automáticamente las dimensiones de las diapositivas. Como tal, es posible que necesites utilizar utilidades adicionales o estilos personalizados para dimensionar adecuadamente el contenido. Si bien los carruseles admiten controles e indicadores anteriores y siguientes, no son necesarios explícitamente. Agrega y personaliza como mejor te parezca.
Debes agregar la clase .active a una de las diapositivas, de lo contrario el carrusel no será visible. También asegúrate de establecer un id único en .carousel para controles opcionales, especialmente si estás utilizando varios carruseles en una sola página. Los elementos de control e indicador deben tener un atributo data-bs-target (o href para enlaces) que coincida con el id del .carousel.
Indicadores
Puedes agregar indicadores al carrusel, junto con los controles anterior/siguiente. Los indicadores permiten a los usuarios saltar directamente a una diapositiva en particular.
Subtítulos
Puedes agregar títulos a tus diapositivas con el elemento .carousel-caption dentro de cualquier .carousel-item. Se pueden ocultar fácilmente en viewports más pequeñas, como se muestra a continuación, con utilidades de visualización opcionales. Los ocultamos inicialmente con .d-none y los recuperamos en dispositivos de tamaño mediano con .d-md-block.
Crossfade
Agrega .carousel-fade a tu carrusel para animar diapositivas con una transición de desvanecimiento en lugar de un desplazamiento. Dependiendo del contenido de su carrusel (por ejemplo, diapositivas de solo texto), es posible que desees agregar .bg-body o algún CSS personalizado a los .carousel-item para lograr un fundido cruzado adecuado.
Carruseles de reproducción automática
Puedes hacer que tus carruseles se reproduzcan automáticamente al cargar la página configurando la opción ride en carousel. Los carruseles de reproducción automática se detienen automáticamente mientras se pasa el mouse. Este comportamiento se puede controlar con la opción pause. En los navegadores que admiten la API de visibilidad de página, el carrusel dejará de funcionar cuando la página web no sea visible para el usuario (como cuando la pestaña del navegador está inactiva o cuando la ventana del navegador está minimizada).
Cuando la opción ride está configurada en true, en lugar de carousel, el carrusel no comenzará a circular automáticamente al cargar la página. En cambio, solo comenzará después de la primera interacción del usuario.
Intervalo .carousel-item individual
Agrega data-bs-interval="" a un .carousel-item para cambiar la cantidad de tiempo de retraso entre cada paso automático al siguiente elemento.
Carruseles de reproducción automática sin controles
Aquí tienes un carrusel solo con diapositivas. Ten en cuenta la presencia de .d-block y .w-100 en las imágenes del carrusel para evitar la alineación de imágenes predeterminada del navegador.
Desactivar el deslizamiento táctil
Los carruseles admiten deslizar el dedo hacia la izquierda o hacia la derecha en dispositivos con pantalla táctil para pasar de una diapositiva a otra. Esto se puede desactivar configurando la opción touch en false.
Variante oscura del componente Carrusel
Obsoleto en v5.3.0
Agrega .carousel-dark al .carousel para obtener controles, indicadores y subtítulos más oscuros. Los controles se invierten en comparación con su relleno blanco predeterminado con la propiedad CSS filter. Los títulos y controles tienen variables Sass adicionales que personalizan el color y el background-color.
Transición personalizada
La duración de la transición de .carousel-item se puede cambiar con la variable Sass $carousel-transition-duration antes de compilar o estilos personalizados si estás utilizando el CSS compilado. Si se aplican varias transiciones, asegúrate de que la transición de transformación esté definida primero (por ejemplo, transition: transform 2s ease, opacity .5s ease-out).
Utiliza atributos de datos para controlar fácilmente la posición del carrusel. data-bs-slide acepta las palabras clave prev o next, que alteran la posición de la diapositiva en relación con su posición actual. Alternativamente, usa data-bs-slide-to para pasar un índice de diapositiva sin formato al carrusel data-bs-slide-to="2", que cambia la posición de la diapositiva a un índice particular que comienza con 0.
Vía JavaScript
Llama al carrusel manualmente con:
Opciones
Como las opciones se pueden pasar a través de atributos de datos o JavaScript, puedes agregar un nombre de opción a data-bs-, como en data-bs-animation="{value}". Asegúrate de cambiar el tipo de caso del nombre de la opción de “camelCase” a “kebab-case” al pasar las opciones a través de atributos de datos. Por ejemplo, utiliza data-bs-custom-class="beautifier" en lugar de data-bs-customClass="beautifier".
A partir de Bootstrap 5.2.0, todos los componentes admiten un atributo de datos experimental reservado data-bs-config que puede albergar datos simples de configuración del componente como una cadena JSON. Cuando un elemento tiene los atributos data-bs-config='{"delay":0, "title":123}' y data-bs-title="456", el valor final de title será 456 y los atributos de datos separados sobrescribirán los valores proporcionados en data-bs-config. Además, los atributos de datos existentes pueden albergar valores JSON como data-bs-delay='{"show":0,"hide":150}'.
El objeto de configuración final es el resultado combinado de data-bs-config, data-bs- y js object donde el último valor-clave dado sobrescribe los demás.
Nombre
Tipo
Predeterminado
Descripción
interval
número
5000
La cantidad de tiempo que se debe demorar entre el ciclo automático de un elemento.
keyboard
boolean
true
Si el carrusel debe reaccionar a los eventos del teclado.
pause
string, boolean
"hover"
Si se configura en "hover", pausa el ciclo del carrusel en mouseenter y reanuda el ciclo del carrusel en mouseleave. Si se establece en false, al pasar el cursor sobre el carrusel no se detendrá. En dispositivos táctiles, cuando se configura en "hover", el ciclo se detendrá en touchend (una vez que el usuario termine de interactuar con el carrusel) durante dos intervalos, antes de reanudarse automáticamente. Esto se suma al comportamiento del mouse.
ride
string, boolean
false
Si se establece en true, el carrusel se reproduce automáticamente después de que el usuario recorre manualmente el primer elemento. Si se establece en "carousel", reproduce automáticamente el carrusel al cargar.
touch
boolean
true
Si el carrusel debe admitir interacciones de deslizamiento hacia la izquierda o hacia la derecha en dispositivos con pantalla táctil.
wrap
boolean
true
Si el carrusel debe realizar ciclos continuos o tener paradas bruscas.
Métodos
Todos los métodos API son asincrónicos e inician una transición. Regresan al punto de la llamada tan pronto como se inicia la transición, pero antes de que finalice. Además, se ignorará una llamada a un método en un componente en transición. Obtén más información en nuestra documentación de JavaScript.
Puedes crear una instancia de carrusel con el constructor de carrusel y pasar cualquier opción adicional. Por ejemplo, para inicializar manualmente un carrusel de reproducción automática (suponiendo que no esté usando el atributo data-bs-ride="carousel" en el marcado en sí) con un intervalo específico y con la compatibilidad táctil deshabilitada, puedes usar:
Método
Descripción
cycle
Comienza a recorrer los elementos del carrusel de izquierda a derecha.
dispose
Destruye el carrusel de un elemento. (Elimina los datos almacenados en el elemento DOM)
getInstance
Método estático que te permite obtener la instancia del carrusel asociada a un elemento DOM. Puedes usarlo así: bootstrap.Carousel.getInstance(element).
getOrCreateInstance
Método estático que devuelve una instancia de carrusel asociada a un elemento DOM, o crea una nueva en caso de que no haya sido inicializada. Puedes usarlo así: bootstrap.Carousel.getOrCreateInstance(element).
next
Pasa al siguiente elemento. Vuelve al punto de la llamada antes de que se muestre el siguiente elemento (por ejemplo, antes de que ocurra el evento slid.bs.carousel).
nextWhenVisible
No pases del carrusel al siguiente cuando la página, el carrusel o el padre del carrusel no estén visibles. Vuelve al punto de la llamada antes de que se haya mostrado el elemento de destino.
pause
Evita que el carrusel recorra los elementos.
prev
Vuelve al elemento anterior. Vuelve al punto de la llamada antes de que se haya mostrado el elemento anterior (por ejemplo, antes de que ocurra el evento slid.bs.carousel).
to
Cicla el carrusel a un cuadro particular (basado en 0, similar a una matriz). Vuelve al punto de la llamada antes de que se haya mostrado el elemento de destino (por ejemplo, antes de que ocurra el evento slid.bs.carousel).
Eventos
La clase de carrusel de Bootstrap expone dos eventos para conectarse a la funcionalidad del carrusel. Ambos eventos tienen las siguientes propiedades adicionales:
direction: La dirección en la que se desliza el carrusel (ya sea "left" o "right").
relatedTarget: el elemento DOM que se desliza en su lugar como elemento activo.
from: El índice del elemento actual
to: El índice del siguiente elemento
Todos los eventos del carrusel se activan en el propio carrusel (es decir, en el <div class="carousel">).
Tipo de evento
Descripción
slid.bs.carousel
Se activa cuando el carrusel ha completado su transición de diapositivas.
slide.bs.carousel
Se activa inmediatamente cuando se invoca el método de instancia slide.