Popovers
Documentación e exemplos para engadir popovers Bootstrap, como os que se atopan en iOS, a calquera elemento do teu sitio.
Cousas que debes saber ao usar o complemento popover:
- Os popovers confían na biblioteca de terceiros Popper.js para o posicionamento. Debes incluír popper.min.js antes de bootstrap.js ou usar
bootstrap.bundle.min.js
/bootstrap.bundle.js
que contén Popper.js para que funcionen os popovers. - Os popovers requiren o complemento de información sobre ferramentas como dependencia.
- Se estás construíndo o noso JavaScript desde a orixe, require
util.js
. - Os popovers están activados por motivos de rendemento, polo que debes inicializalos vostede mesmo .
- A lonxitude cero
title
econtent
os valores nunca mostrarán un popover. - Especifique
container: 'body'
para evitar problemas de renderizado en compoñentes máis complexos (como os nosos grupos de entrada, grupos de botóns, etc.). - Non funcionará activar popovers en elementos ocultos.
- Os popovers para
.disabled
oudisabled
elementos deben activarse nun elemento de envoltura. - Cando se activan desde áncoras que envolven varias liñas, os popovers centraranse entre o ancho total das áncoras. Use
white-space: nowrap;
no seu<a>
s para evitar este comportamento. - Os popovers deben ocultarse antes de que se eliminen do DOM os seus elementos correspondentes.
Continúa lendo para ver como funcionan os popovers con algúns exemplos.
Unha forma de inicializar todos os popovers nunha páxina sería seleccionalos polo seu data-toggle
atributo:
Cando teñas algúns estilos nun elemento principal que interfiran cun popover, quererás especificar un personalizado container
para que o HTML do popover apareza nese elemento.
<button type="button" class="btn btn-lg btn-danger" data-toggle="popover" title="Popover title" data-content="And here's some amazing content. It's very engaging. Right?">Click to toggle popover</button>
Hai catro opcións dispoñibles: arriba, dereita, inferior e aliñada á esquerda.
Use o focus
disparador para descartar popovers no seguinte clic do usuario nun elemento diferente do elemento de alternancia.
Requírese un marcado específico para descartar ao facer clic ao seguinte
Para un comportamento adecuado entre navegadores e plataformas, debes usar a <a>
etiqueta, non a <button>
etiqueta, e tamén debes incluír un tabindex
atributo.
<a tabindex="0" class="btn btn-lg btn-danger" role="button" data-toggle="popover" data-trigger="focus" title="Dismissible popover" data-content="And here's some amazing content. It's very engaging. Right?">Dismissible popover</a>
Os elementos co disabled
atributo non son interactivos, o que significa que os usuarios non poden pasar o rato nin facer clic neles para activar un popover (ou información sobre ferramentas). Como solución alternativa, quererá activar o popover desde un envoltorio <div>
ou <span>
e anular o pointer-events
elemento desactivado.
Para os activadores de popover desactivados, tamén podes preferir data-trigger="hover"
que o popover apareza como un feedback visual inmediato para os teus usuarios, xa que quizais non esperen facer clic nun elemento desactivado.
<span class="d-inline-block" data-toggle="popover" data-content="Disabled popover">
<button class="btn btn-primary" style="pointer-events: none;" type="button" disabled>Disabled button</button>
</span>
Activar popovers mediante JavaScript:
As opcións pódense pasar a través de atributos de datos ou JavaScript. Para os atributos de datos, engada o nome da opción a data-
, como en data-animation=""
.
Nome | Tipo | Por defecto | Descrición |
---|---|---|---|
animación | booleano | verdade | Aplique unha transición de fundido CSS ao popover |
envase | cadea | elemento | falso | falso | Engade o popover a un elemento específico. Exemplo: |
contido | cadea | elemento | función | '' | Valor de contido predeterminado se Se se dá unha función, chamarase coa súa |
atraso | número | obxecto | 0 | Atraso para mostrar e ocultar o popover (ms): non se aplica ao tipo de activación manual Se se proporciona un número, aplícase un atraso tanto para ocultar como para mostrar A estrutura do obxecto é: |
html | booleano | falso | Insira HTML no popover. text Se é falso, empregarase o método de jQuery para inserir contido no DOM. Usa texto se estás preocupado polos ataques XSS. |
colocación | cadea | función | 'correcto' | Como colocar o popover - auto | arriba | inferior | esquerda | certo. Cando se usa unha función para determinar a colocación, chámase co nodo DOM popover como primeiro argumento e o nodo DOM do elemento desencadeante como segundo. O |
selector | cadea | falso | falso | Se se proporciona un selector, os obxectos popover delegaranse nos obxectivos especificados. Na práctica, isto úsase para permitir que o contido HTML dinámico teña aparellos emergentes engadidos. Vexa isto e un exemplo informativo . |
modelo | corda | '<div class="popover" role="tooltip"><div class="arrow"></div><h3 class="popover-header"></h3><div class="popover-body"></div></div>' |
HTML base para usar ao crear o popover. Os popovers Os popovers
O elemento de envoltura máis externo debería ter a |
título | cadea | elemento | función | '' | Valor predeterminado do título se Se se dá unha función, chamarase coa súa |
disparador | corda | 'click' | Como se activa o popover: fai clic en | pasar o rato | foco | manual. Podes pasar varios disparadores; separalos cun espazo. `manual` non se pode combinar con ningún outro disparador. |
compensar | número | corda | 0 | Desfase do popover en relación ao seu obxectivo. Para obter máis información, consulte os documentos de offset de Popper.js . |
colocación de reserva | cadea | matriz | 'flip' | Permitir especificar a posición que utilizará Popper no respaldo. Para obter máis información, consulte os documentos de comportamento de Popper.js |
límite | cadea | elemento | 'scrollParent' | Límite de restricción de desbordamento do popover. Acepta os valores de 'viewport' , 'window' , 'scrollParent' , ou unha referencia HTMLElement (só JavaScript). Para obter máis información, consulte os documentos preventOverflow de Popper.js . |
Atributos de datos para popovers individuais
As opcións para popovers individuais pódense especificar alternativamente mediante o uso de atributos de datos, como se explicou anteriormente.
Métodos asíncronos e transicións
Todos os métodos da API son asíncronos e inician unha transición . Volven ao interlocutor en canto se inicia a transición pero antes de que remate . Ademais, ignorarase unha chamada de método nun compoñente en transición .
Consulte a nosa documentación de JavaScript para obter máis información.
Inicia os popovers para unha colección de elementos.
Revela o popover dun elemento. Volve ao interlocutor antes de que se amosase o popover (é dicir, antes de shown.bs.popover
que se produza o evento). Isto considérase un desencadeamento "manual" do popover. Os popovers cuxo título e contido son de lonxitude cero nunca se mostran.
Oculta o popover dun elemento. Volve ao interlocutor antes de que se ocultase o popover (é dicir, antes de hidden.bs.popover
que ocorra o evento). Isto considérase un desencadeamento "manual" do popover.
Alterna o popover dun elemento. Volve ao interlocutor antes de que se amosase ou ocultase o popover (é dicir, antes de que se produza o evento shown.bs.popover
ou ). hidden.bs.popover
Isto considérase un desencadeamento "manual" do popover.
Oculta e destrúe o popover dun elemento. Os popovers que usan a delegación (que se crean mediante a selector
opción ) non se poden destruír individualmente nos elementos desencadeantes descendentes.
Dá a posibilidade de mostrar o popover dun elemento. Os popovers están activados por defecto.
Elimina a posibilidade de mostrar o popover dun elemento. O popover só se poderá mostrar se se volve activar.
Alterna a posibilidade de mostrar ou ocultar o popover dun elemento.
Actualiza a posición do popover dun elemento.
Tipo de evento | Descrición |
---|---|
mostrar.bs.popover | Este evento desenvólvese inmediatamente cando show se chama ao método de instancia. |
mostrado.bs.popover | Este evento desenvólvese cando o popover se fixo visible para o usuario (esperará a que se completen as transicións CSS). |
ocultar.bs.popover | Este evento desenvólvese inmediatamente cando hide se chamou ao método de instancia. |
hidden.bs.popover | Este evento desenvólvese cando o popover rematou de ocultarse ao usuario (esperará a que se completen as transicións CSS). |
inserido.bs.popover | Este evento desenvólvese despois do show.bs.popover evento cando o modelo popover foi engadido ao DOM. |