Saltearse al contenido

El componente Popover de Bootstrap

Documentación y ejemplos para agregar ventanas emergentes de Bootstrap, como las que se encuentran en iOS, a cualquier elemento de tu sitio.

Cosas que debes saber al usar el complemento popover:

  • Los popovers dependen de la biblioteca de terceros Popper para su posicionamiento. Debes incluir popper.min.js antes de bootstrap.js, o utiliza un bootstrap.bundle.min.js que contenga Popper.
  • Los popovers requieren el complemento popover como dependencia.
  • Los popovers son opcionales por motivos de rendimiento, por lo que debes inicializarlos tú mismo.
  • Los valores title y content de longitud cero nunca mostrarán una ventana emergente.
  • Especifica container: 'body' para evitar problemas de renderizado en componentes más complejos (como nuestros grupos de entrada, grupos de botones, etc.).
  • Activar ventanas emergentes en elementos ocultos no funcionará.
  • Los elementos emergentes para los elementos .disabled o disabled deben activarse en un elemento contenedor.
  • Cuando se activan desde anchors (enlaces) que abarcan varias líneas, los popovers se centrarán entre el ancho total de los enlaces. Utiliza .text-nowrap en tus <a>para evitar este comportamiento.
  • Los popovers deben ocultarse antes de que sus elementos correspondientes se eliminen del DOM.
  • Los popovers se pueden activar gracias a un elemento dentro de un DOM oculto.

Sigue leyendo para ver cómo funcionan los popovers con algunos ejemplos.

Ejemplos del componente Popover

Habilitar popovers

Como se mencionó anteriormente, debes inicializar los popovers antes de poder usarlos. Una forma de inicializar todos los popovers de una página sería seleccionarlos por su atributo data-bs-toggle, así:

JavaScript
const popoverTriggerList = document.querySelectorAll('[data-bs-toggle="popover"]')
const popoverList = [...popoverTriggerList].map(popoverTriggerEl => new bootstrap.Popover(popoverTriggerEl))

Demostración en vivo

Usamos JavaScript similar al fragmento anterior para representar el siguiente popover en vivo. Los títulos se configuran mediante data-bs-title y el contenido del cuerpo se establece mediante data-bs-content.

HTML
<button type="button" class="btn btn-lg btn-danger" data-bs-toggle="popover" data-bs-title="Popover title" data-bs-content="And here's some amazing content. It's very engaging. Right?">
Haz clic para alternar la ventana emergente
</button>

Cuatro direcciones

Hay cuatro opciones disponibles: arriba, derecha, abajo e izquierda. Las instrucciones se reflejan cuando se usa Bootstrap en RTL. Establece data-bs-placement para cambiar la dirección.

HTML
<button type="button" class="btn btn-secondary" data-bs-container="body" data-bs-toggle="popover" data-bs-placement="top" data-bs-content="Top popover" aria-describedby="popover317829">
Popover superior
</button>
<button type="button" class="btn btn-secondary" data-bs-container="body" data-bs-toggle="popover" data-bs-placement="right" data-bs-content="Right popover" aria-describedby="popover714521">
Popover a la derecha
</button>
<button type="button" class="btn btn-secondary" data-bs-container="body" data-bs-toggle="popover" data-bs-placement="bottom" data-bs-content="Bottom popover" aria-describedby="popover762852">
Popover inferior
</button>
<button type="button" class="btn btn-secondary" data-bs-container="body" data-bs-toggle="popover" data-bs-placement="left" data-bs-content="Left popover" aria-describedby="popover897029">
Popover a la izquierda
</button>

Contenedor personalizado container

Cuando tienes algunos estilos en un elemento padre que interfieren con una ventana emergente, querrás especificar un container personalizado para que el HTML de la ventana emergente aparezca dentro de ese elemento. Esto es común en tablas responsive, grupos de entrada y similares.

JavaScript
const popover = new bootstrap.Popover('.example-popover', {
container: 'body'
})

Otra situación en la que querrás establecer un container personalizado explícito son los popovers dentro de un diálogo modal, para asegurarte de que la ventana emergente en sí se agregue al modal. Esto es particularmente importante para los popovers que contienen elementos interactivos: los cuadros de diálogo modales atraparán el foco, por lo que, a menos que el popover sea un elemento secundario del modal, los usuarios no podrán enfocar ni activar estos elementos interactivos.

JavaScript
const popover = new bootstrap.Popover('.example-popover', {
container: '.modal-body'
})

Popovers personalizados


Agregado en v5.2.0

Puedes personalizar la apariencia de los popovers usando variables CSS. Configuramos una clase personalizada con data-bs-custom-class="custom-popover" para definir el alcance de nuestra apariencia personalizada y usarla para sobrescribir algunas de las variables CSS locales.

site/assets/scss/_component-examples.scss

site/assets/scss/_component-examples.scss
.custom-popover {
--bs-popover-max-width: 200px;
--bs-popover-border-color: var(--bd-violet-bg);
--bs-popover-header-bg: var(--bd-violet-bg);
--bs-popover-header-color: var(--bs-white);
--bs-popover-body-padding-x: 1rem;
--bs-popover-body-padding-y: .5rem;
}
HTML
<button type="button" class="btn btn-secondary" data-bs-toggle="popover" data-bs-placement="right"
data-bs-custom-class="custom-popover" data-bs-title="Popover personalizado"
data-bs-content="Este popover tiene un tema a través de variables CSS.">
Popover personalizado
</button>

Descartar en el siguiente clic

Utiliza el disparador focus para descartar ventanas emergentes en el siguiente clic del usuario en un elemento que no sea el elemento de alternancia.

HTML
<a tabindex="0" class="btn btn-lg btn-danger" role="button" data-bs-toggle="popover" data-bs-trigger="focus"
data-bs-title="Dismissible popover"
data-bs-content="And here's some amazing content. It's very engaging. Right?">
Popover descartable
</a>
JavaScript
const popover = new bootstrap.Popover('.popover-dismiss', {
trigger: 'focus'
})

Elementos deshabilitados

Los elementos con el atributo disabled no son interactivos, lo que significa que los usuarios no pueden pasar el cursor sobre ellos ni hacer clic en ellos para activar una ventana emergente (o un tooltips). Como solución alternativa, querrás activar la ventana emergente desde un contenedor <div> o <span>, idealmente enfocado desde el teclado usando tabindex="0".

Para los activadores de ventana emergente deshabilitados, también puedes preferir data-bs-trigger="hover focus" para que la ventana emergente aparezca como retroalimentación visual inmediata para tus usuarios ya que es posible que no intenten hacer clic en un elemento deshabilitado.

HTML
<span class="d-inline-block" tabindex="0" data-bs-toggle="popover" data-bs-trigger="hover focus"
data-bs-content="Disabled popover">
<button class="btn btn-primary" type="button" disabled="">Botón deshabilitado</button>
</span>

Personalización del CSS del componente

Variables Sass del componente


Agregado en v5.2.0

Como parte del enfoque de variables CSS en evolución de Bootstrap, los popovers ahora usan variables CSS locales en .popover para una personalización mejorada en tiempo real. Los valores de las variables CSS se establecen a través de Sass, por lo que la personalización de Sass también es compatible.

scss/_popover.scss

scss/_popover.scss
--#{$prefix}popover-zindex: #{$zindex-popover};
--#{$prefix}popover-max-width: #{$popover-max-width};
@include rfs($popover-font-size, --#{$prefix}popover-font-size);
--#{$prefix}popover-bg: #{$popover-bg};
--#{$prefix}popover-border-width: #{$popover-border-width};
--#{$prefix}popover-border-color: #{$popover-border-color};
--#{$prefix}popover-border-radius: #{$popover-border-radius};
--#{$prefix}popover-inner-border-radius: #{$popover-inner-border-radius};
--#{$prefix}popover-box-shadow: #{$popover-box-shadow};
--#{$prefix}popover-header-padding-x: #{$popover-header-padding-x};
--#{$prefix}popover-header-padding-y: #{$popover-header-padding-y};
@include rfs($popover-header-font-size, --#{$prefix}popover-header-font-size);
--#{$prefix}popover-header-color: #{$popover-header-color};
--#{$prefix}popover-header-bg: #{$popover-header-bg};
--#{$prefix}popover-body-padding-x: #{$popover-body-padding-x};
--#{$prefix}popover-body-padding-y: #{$popover-body-padding-y};
--#{$prefix}popover-body-color: #{$popover-body-color};
--#{$prefix}popover-arrow-width: #{$popover-arrow-width};
--#{$prefix}popover-arrow-height: #{$popover-arrow-height};
--#{$prefix}popover-arrow-border: var(--#{$prefix}popover-border-color);

Variables Sass generales relacionadas

scss/_variables.scss

scss/_variables.scss
$popover-font-size: $font-size-sm;
$popover-bg: var(--#{$prefix}body-bg);
$popover-max-width: 276px;
$popover-border-width: var(--#{$prefix}border-width);
$popover-border-color: var(--#{$prefix}border-color-translucent);
$popover-border-radius: var(--#{$prefix}border-radius-lg);
$popover-inner-border-radius: calc(#{$popover-border-radius} - #{$popover-border-width}); // stylelint-disable-line function-disallowed-list
$popover-box-shadow: var(--#{$prefix}box-shadow);
$popover-header-font-size: $font-size-base;
$popover-header-bg: var(--#{$prefix}secondary-bg);
$popover-header-color: $headings-color;
$popover-header-padding-y: .5rem;
$popover-header-padding-x: $spacer;
$popover-body-color: var(--#{$prefix}body-color);
$popover-body-padding-y: $spacer;
$popover-body-padding-x: $spacer;
$popover-arrow-width: 1rem;
$popover-arrow-height: .5rem;

Uso del componente Popover

Habilitar ventanas emergentes a través de JavaScript:

JavaScript
const exampleEl = document.getElementById('example')
const popover = new bootstrap.Popover(exampleEl, options)

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.

NombreTipoPredeterminadoDescripción
allowListobjectValor predeterminadoObjeto que contiene atributos y etiquetas permitidos.
animationbooleantrueAplica una transición de desvanecimiento CSS al popover.
boundarystring, element'clippingParents'Límite de restricción de desbordamiento del popover (se aplica solo al modificador preventOverflow de Popper). De forma predeterminada, es 'clippingParents' y puede aceptar una referencia HTMLElement (solo a través de JavaScript). Para obtener más información, consulta la documentación de detectOverflowde Popper.
containerstring, element, falsefalseAgrega el popover a un elemento específico. Ejemplo: container: 'body'. Esta opción es particularmente útil porque te permite colocar la ventana emergente en el flujo del documento cerca del elemento desencadenante, lo que evitará que la ventana emergente flote lejos del elemento desencadenante durante el cambio de tamaño de la ventana.
contentstring, element, function''El contenido de texto del popover. Si se proporciona una función, se llamará con su referencia this establecida en el elemento al que está adjunto el popover.
customClassstring, function''Agrega clases al popover cuando se muestra. Ten en cuenta que estas clases se agregarán además de cualquier clase especificada en la plantilla. Para agregar varias clases, sepáralas con espacios: 'class-1 class-2'. También puedes pasar una función que debería devolver una única cadena que contenga nombres de clases adicionales.
delaynumber, object0Tiempo de espera para mostrar y ocultar el popover (ms): no se aplica al tipo de activación manual. Si se proporciona un número, se aplica un retraso tanto para ocultar como para mostrar. La estructura del objeto es: delay: { "show": 500, "hide": 100 }.
fallbackPlacementsstring, array['top', 'right', 'bottom', 'left']Define ubicaciones alternativas proporcionando una lista de ubicaciones en una matriz (en orden de preferencia). Para obtener más información, consulta la documentación de comportamiento de Popper.
htmlbooleanfalsePermitir HTML en la ventana emergente. Si es true, las etiquetas HTML en el title de la ventana emergente se representarán en la ventana emergente. Si es false, la propiedad innerText se utilizará para insertar contenido en el DOM. Utiliza texto si te preocupan los ataques XSS.
offsetnumber, string, function[0, 0]Desplazamiento del popover en relación con su objetivo. Puedes pasar una cadena en atributos de datos con valores separados por comas como: data-bs-offset="10,20". Cuando se usa una función para determinar el desplazamiento, se llama con un objeto que contiene la ubicación del popper, la referencia y los rectificadores del popper como primer argumento. El nodo DOM del elemento desencadenante se pasa como segundo argumento. La función debe devolver una matriz con dos números: skidding, distance. Para obtener más información, consulta la documentación de offset de Popper.
placementstring, function'top'Cómo posicionar el popover: auto, top, bottom, left, right. Cuando se especifica auto , reorientará dinámicamente la ventana emergente. Cuando se utiliza una función para determinar la ubicación, se llama con el nodo DOM emergente como primer argumento y el nodo DOM del elemento desencadenante como segundo. El contexto this se establece en la instancia de ventana emergente.
popperConfignull, object, functionnullPara cambiar la configuración predeterminada de Popper de Bootstrap, consulta Configuración de Popper. Cuando se usa una función para crear la configuración de Popper, se llama con un objeto que contiene la configuración de Popper predeterminada de Bootstrap. Te ayuda a utilizar y fusionar el valor predeterminado con tu propia configuración. La función debe devolver un objeto de configuración para Popper.
sanitizebooleantrueActiva o desactiva la desinfección. Si se activan las opciones 'template', 'content' y 'title' se desinfectarán.
sanitizeFnnull, functionnullAquí puedes proporcionar tu propia función de desinfección. Esto puede resultar útil si prefieres utilizar una biblioteca dedicada para realizar la desinfección.
selectorstring, falsefalseSi se proporciona un selector, los objetos emergentes se delegarán a los objetivos especificados. En la práctica, esto también se utiliza para aplicar ventanas emergentes a elementos DOM agregados dinámicamente (compatible con jQuery.on). Consulta este problema y un ejemplo informativo. Nota: el atributo title no debe usarse como selector.
templatestring'<div class="popover" role="tooltip"><div class="popover-arrow"></div><div class="popover-inner"></div></div>'HTML base para usar al crear el popover. El title del popover se inyectará en el .popover-inner. .popover-arrow se convertirá en la flecha del popover. El elemento contenedor más externo debe tener la clase .popover y role="tooltip".
titlestring, element, function''El título del popover. Si se proporciona una función, se llamará con su referencia this establecida en el elemento al que está adjunto el popover.
triggerstring'hover focus'Cómo se activa el popover: click, hover, manual. Puedes pasar varios factores desencadenantes; sepáralos con un espacio. 'manual' indica que el popover se activará mediante programación mediante los métodos .popover('show'), .popover('hide') y .popover('toggle'); este valor no se puede combinar con ningún otro activador. 'hover' por sí solo generará ventanas emergentes que no se pueden activar a través del teclado y solo deben usarse si existen métodos alternativos para transmitir la misma información a los usuarios del teclado.

Usar la función con popperConfig

JavaScript
const popover = new bootstrap.Popover(element, {
popperConfig(defaultBsPopperConfig) {
// const newPopperConfig = {...}
// use defaultBsPopperConfig if needed...
// return newPopperConfig
}
})

Métodos

MétodoDescripción
disableElimina la posibilidad de que se muestre la ventana emergente de un elemento. La ventana emergente solo podrá mostrarse si se vuelve a habilitar.
disposeOculta y destruye la ventana emergente de un elemento (elimina los datos almacenados en el elemento DOM). Los elementos emergentes que utilizan delegación (que se crean usando la opción selector, ) no se pueden destruir individualmente en elementos desencadenantes descendientes.
enableLe da al popover de un elemento la posibilidad de mostrarse. Las ventanas emergentes están habilitadas de forma predeterminada.
getInstanceStatic método que te permite obtener la instancia emergente asociada con un elemento DOM.
getOrCreateInstanceStatic método que te permite obtener la instancia emergente asociada con un elemento DOM, o crear una nueva en caso de que no haya sido inicializada.
hideOculta la ventana emergente de un elemento. Vuelve al punto de la llamada antes de que la ventana emergente se haya ocultado (es decir, antes de que ocurra el evento hidden.bs.popover). Esto se considera una activación “manual” del popover.
setContentProporciona una manera de cambiar el contenido del popover después de su inicialización.
showRevela el popover de un elemento. Vuelve al punto de la llamada antes de que se haya mostrado realmente la ventana emergente (es decir, antes de que ocurra el evento shown.bs.popover). Esto se considera una activación “manual” del popover. Los popovers cuyo título y contenido tengan longitud cero nunca se muestran.
toggleAlterna la ventana emergente de un elemento. Vuelve al punto de la llamada antes de que la ventana emergente se haya mostrado u ocultado (es decir, antes de que ocurra el evento shown.bs.popover o hidden.bs.popover). Esto se considera una activación “manual” del popover.
toggleEnabledAlterna la capacidad de mostrar u ocultar la ventana emergente de un elemento.
updateActualiza la posición del popover de un elemento.
JavaScript
// getOrCreateInstance example
const popover = bootstrap.Popover.getOrCreateInstance('#example') // Returns a Bootstrap popover instance
// setContent example
myPopover.setContent({
'.popover-header': 'another title',
'.popover-body': 'another content'
})

Eventos

EventoDescripción
hide.bs.popoverEste evento se activa inmediatamente cuando se llama al método de instancia hide.
hidden.bs.popoverEste evento se activa cuando el popover termina de ocultarse al usuario (esperará a que se completen las transiciones CSS).
inserted.bs.popoverEste evento se activa después del evento show.bs.popover cuando la plantilla emergente se agrega al DOM.
show.bs.popoverEste evento se activa inmediatamente cuando se llama al método de instancia show.
shown.bs.popoverEste evento se activa cuando la ventana emergente se hace visible para el usuario (esperará a que se completen las transiciones CSS).
JavaScript
const myPopoverTrigger = document.getElementById('myPopover')
myPopoverTrigger.addEventListener('hidden.bs.popover', () => {
// do something...
})