Popovers
Documentation et exemples pour ajouter des popovers Bootstrap, comme ceux trouvés dans iOS, à n'importe quel élément de votre site.
Aperçu
Choses à savoir lors de l'utilisation du plugin popover :
- Les popovers s'appuient sur la bibliothèque tierce Popper pour le positionnement. Vous devez inclure popper.min.js avant bootstrap.js ou utiliser
bootstrap.bundle.min.js
/bootstrap.bundle.js
qui contient Popper pour que les popovers fonctionnent ! - Les popovers nécessitent le tooltip plugin en tant que dépendance.
- Les popovers sont opt-in pour des raisons de performances, vous devez donc les initialiser vous-même.
- La longueur nulle
title
etcontent
les valeurs n'afficheront jamais de popover. - Spécifier
container: 'body'
pour éviter les problèmes de rendu dans des composants plus complexes (comme nos groupes d'entrée, groupes de boutons, etc.). - Le déclenchement de popovers sur des éléments cachés ne fonctionnera pas.
- Les popovers pour les éléments
.disabled
oudisabled
doivent être déclenchés sur un élément wrapper. - Lorsqu'ils sont déclenchés à partir d'ancres qui s'étendent sur plusieurs lignes, les popovers seront centrés entre la largeur globale des ancres. Utilisez
.text-nowrap
sur votre<a>
s pour éviter ce comportement. - Les popovers doivent être masqués avant que leurs éléments correspondants ne soient supprimés du DOM.
- Les popovers peuvent être déclenchés grâce à un élément à l'intérieur d'un DOM shadow.
prefers-reduced-motion
equête multimédia. Voir la section mouvement réduit de notre documentation sur l'accessibilité.
Continuez à lire pour voir comment les popovers fonctionnent avec quelques exemples.
Exemple: Activer les popovers partout
Une façon d'initialiser tous les popovers sur une page serait de les sélectionner par leur data-bs-toggle
attribut:
var popoverTriggerList = [].slice.call(document.querySelectorAll('[data-bs-toggle="popover"]'))
var popoverList = popoverTriggerList.map(function (popoverTriggerEl) {
return new bootstrap.Popover(popoverTriggerEl)
})
Exemple: Utilisation de l'option container
Lorsque vous avez des styles sur un élément parent qui interfèrent avec un popover, vous voudrez spécifier une coutume container
afin que le HTML du popover apparaisse dans cet élément à la place.
var popover = new bootstrap.Popover(document.querySelector('.example-popover'), {
container: 'body'
})
Exemple
<button type="button" class="btn btn-lg btn-danger" data-bs-toggle="popover" title="Popover title" data-bs-content="And here's some amazing content. It's very engaging. Right?">Click to toggle popover</button>
Quatre directions
Quatre options sont disponibles : aligné en haut, à droite, en bas et à gauche. Les directions sont mises en miroir lors de l'utilisation de Bootstrap dans RTL.
<button type="button" class="btn btn-secondary" data-bs-container="body" data-bs-toggle="popover" data-bs-placement="top" data-bs-content="Top popover">
Popover on top
</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">
Popover on right
</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">
Popover on bottom
</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">
Popover on left
</button>
Ignorer au prochain clic
Utiliser le focus
déclencheur pour fermer les popovers au prochain clic de l'utilisateur sur un élément différent de l'élément bascule.
Balisage spécifique requis pour le rejet au prochain clic
Pour un comportement correct entre navigateurs et plates-formes, vous devez utiliser la <a>
balise, pas la <button>
balise, et vous devez également inclure un tabindex
attribut.
<a tabindex="0" class="btn btn-lg btn-danger" role="button" data-bs-toggle="popover" data-bs-trigger="focus" title="Dismissible popover" data-bs-content="And here's some amazing content. It's very engaging. Right?">Dismissible popover</a>
var popover = new bootstrap.Popover(document.querySelector('.popover-dismiss'), {
trigger: 'focus'
})
Éléments désactivés
Les éléments avec l' disabled
attribut ne sont pas interactifs, ce qui signifie que les utilisateurs ne peuvent pas les survoler ou cliquer dessus pour déclencher un popover (ou une info-bulle). Comme solution de contournement, vous souhaiterez déclencher le popover à partir d'un wrapper <div>
ou <span>
, idéalement rendu focusable au clavier à l'aide de tabindex="0"
.
Pour les déclencheurs de popover désactivés, vous pouvez également préférer data-bs-trigger="hover focus"
que le popover apparaisse comme un retour visuel immédiat pour vos utilisateurs, car ils ne s'attendent peut-être pas à cliquer sur un élément désactivé.
<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>Disabled button</button>
</span>
Sass
Variables
$popover-font-size: $font-size-sm;
$popover-bg: $white;
$popover-max-width: 276px;
$popover-border-width: $border-width;
$popover-border-color: rgba($black, .2);
$popover-border-radius: $border-radius-lg;
$popover-inner-border-radius: subtract($popover-border-radius, $popover-border-width);
$popover-box-shadow: $box-shadow;
$popover-header-bg: shade-color($popover-bg, 6%);
$popover-header-color: $headings-color;
$popover-header-padding-y: .5rem;
$popover-header-padding-x: $spacer;
$popover-body-color: $body-color;
$popover-body-padding-y: $spacer;
$popover-body-padding-x: $spacer;
$popover-arrow-width: 1rem;
$popover-arrow-height: .5rem;
$popover-arrow-color: $popover-bg;
$popover-arrow-outer-color: fade-in($popover-border-color, .05);
Utilisation
Activez les popovers via JavaScript :
var exampleEl = document.getElementById('example')
var popover = new bootstrap.Popover(exampleEl, options)
Faire en sorte que les popovers fonctionnent pour les utilisateurs de clavier et de technologie d'assistance
Pour permettre aux utilisateurs du clavier d'activer vos popovers, vous ne devez les ajouter qu'aux éléments HTML qui sont traditionnellement accessibles au clavier et interactifs (tels que des liens ou des contrôles de formulaire). Bien que des éléments HTML arbitraires (tels que <span>
s) puissent être rendus focalisables en ajoutant l' tabindex="0"
attribut, cela ajoutera des taquets de tabulation potentiellement gênants et déroutants sur les éléments non interactifs pour les utilisateurs de clavier, et la plupart des technologies d'assistance n'annoncent actuellement pas le contenu du popover dans cette situation. . De plus, ne comptez pas uniquement sur hover
le déclencheur pour vos popovers, car cela les rendra impossibles à déclencher pour les utilisateurs de clavier.
Bien que vous puissiez insérer du HTML riche et structuré dans les popovers avec l' html
option, nous vous recommandons fortement d'éviter d'ajouter une quantité excessive de contenu. La façon dont les popovers fonctionnent actuellement est qu'une fois affichés, leur contenu est lié à l'élément déclencheur avec l' aria-describedby
attribut . En conséquence, l'intégralité du contenu de la fenêtre contextuelle sera annoncée aux utilisateurs de technologies d'assistance sous la forme d'un flux long et ininterrompu.
De plus, s'il est possible d'inclure également des contrôles interactifs (tels que des éléments de formulaire ou des liens) dans votre popover (en ajoutant ces éléments aux allowList
attributs et balises autorisés), sachez qu'actuellement, le popover ne gère pas l'ordre de focus du clavier. Lorsqu'un utilisateur du clavier ouvre un popover, le focus reste sur l'élément déclencheur, et comme le popover ne suit généralement pas immédiatement le déclencheur dans la structure du document, il n'y a aucune garantie qu'avancer/appuyer sur TAB déplacera un utilisateur de clavier dans le popover lui-même. En bref, le simple fait d'ajouter des contrôles interactifs à un popover est susceptible de rendre ces contrôles inaccessibles/inutilisables pour les utilisateurs de clavier et les utilisateurs de technologies d'assistance, ou à tout le moins de créer un ordre de mise au point global illogique. Dans ces cas, envisagez plutôt d'utiliser une boîte de dialogue modale.
Options
Les options peuvent être transmises via des attributs de données ou JavaScript. Pour les attributs de données, ajoutez le nom de l'option à data-bs-
, comme dans data-bs-animation=""
. Assurez-vous de changer le type de casse du nom de l'option de camelCase à kebab-case lors du passage des options via les attributs de données. Par exemple, au lieu d'utiliser data-bs-customClass="beautifier"
, utiliser data-bs-custom-class="beautifier"
.
sanitize
, sanitizeFn
, et allowList
options et ne peuvent pas être fournies à l'aide d'attributs de données
Nom | Type | Défaut | Description |
---|---|---|---|
animation |
boolean | true |
Appliquer une transition de fondu CSS au popover |
container |
string | element | false | false |
Ajoute le popover à un élément spécifique. Exemple : |
content |
string | element | function | '' |
Valeur de contenu par défaut si Si une fonction est donnée, elle sera appelée avec sa |
delay |
number | object | 0 |
Délai d'affichage et de masquage du popover (ms) - ne s'applique pas au type de déclenchement manuel Si un nombre est fourni, un délai est appliqué à la fois pour masquer/afficher La structure de l'objet est : |
html |
boolean | false |
Insérez HTML dans le popover. Si false, innerText la propriété sera utilisée pour insérer du contenu dans le DOM. Utilisez du texte si vous craignez les attaques XSS. |
placement |
string | function | 'right' |
Comment positionner le popover - auto | haut | bas | gauche | droit. Lorsqu'une fonction est utilisée pour déterminer le placement, elle est appelée avec le nœud DOM popover comme premier argument et le nœud DOM de l'élément déclencheur comme second. Le |
selector |
string | false | false |
Si un sélecteur est fourni, les objets popover seront délégués aux cibles spécifiées. En pratique, cela est utilisé pour permettre au contenu HTML dynamique d'avoir des popovers ajoutés. Voir ceci et un exemple informatif. |
template |
string | '<div class="popover" role="tooltip"><div class="popover-arrow"></div><h3 class="popover-header"></h3><div class="popover-body"></div></div>' |
HTML de base à utiliser lors de la création du popover. Les popovers Les popovers
L'élément wrapper le plus externe doit avoir la |
title |
string | element | function | '' |
Valeur de titre par défaut si Si une fonction est donnée, elle sera appelée avec sa |
trigger |
string | 'click' |
Comment le popover est déclenché - cliquez | planer | concentrer | Manuel. Vous pouvez passer plusieurs déclencheurs ; séparez-les par un espace. manual ne peut être combiné avec aucun autre déclencheur. |
fallbackPlacements |
array | ['top', 'right', 'bottom', 'left'] |
Définissez les emplacements de remplacement en fournissant une liste d'emplacements dans le tableau (par ordre de préférence). Pour plus d'informations, reportez-vous à la documentation sur le comportement de popper |
boundary |
string | element | 'clippingParents' |
Limite de contrainte de débordement du popover (s'applique uniquement au modificateur preventOverflow de Popper). Par défaut, c'est 'clippingParents' et peut accepter une référence HTMLElement (via JavaScript uniquement). Pour plus d'informations, reportez-vous à la documentation detectOverflow. |
customClass |
string | function | '' |
Ajoutez des classes au popover lorsqu'il est affiché. Notez que ces classes seront ajoutées en plus de toutes les classes spécifiées dans le modèle. Pour ajouter plusieurs classes, séparez-les par des espaces : Vous pouvez également passer une fonction qui doit renvoyer une seule chaîne contenant des noms de classe supplémentaires. |
sanitize |
boolean | true |
Activez ou désactivez la désinfection. Si elles sont activées 'template' , 'content' et 'title' seront désinfectées. Voir la section désinfectant dans notre documentation JavaScript .. |
allowList |
object | Default value | Objet qui contient des attributs et des balises autorisés |
sanitizeFn |
null | function | null |
Ici, vous pouvez fournir votre propre fonction de désinfection. Cela peut être utile si vous préférez utiliser une bibliothèque dédiée pour effectuer la désinfection. |
offset |
array | string | function | [0, 8] |
Décalage du popover par rapport à sa cible. Vous pouvez transmettre une chaîne dans les attributs de données avec des valeurs séparées par des virgules comme : Lorsqu'une fonction est utilisée pour déterminer le décalage, elle est appelée avec un objet contenant le placement du popper, la référence et les rectangles du popper comme premier argument. Le nœud DOM de l'élément déclencheur est passé comme second argument. La fonction doit retourner un tableau avec deux nombres : Pour plus d'informations, reportez-vous à la documentation de décalage de popper. |
popperConfig |
null | object | function | null |
Pour modifier la configuration Popper par défaut de Bootstrap, consultez Popper's configuration. Lorsqu'une fonction est utilisée pour créer la configuration Popper, elle est appelée avec un objet qui contient la configuration Popper par défaut de Bootstrap. Il vous aide à utiliser et à fusionner la valeur par défaut avec votre propre configuration. La fonction doit retourner un objet de configuration pour Popper. |
Attributs de données pour les popovers individuels
Les options pour les popovers individuels peuvent également être spécifiées via l'utilisation d'attributs de données, comme expliqué ci-dessus.
Utilisation de la fonction avec popperConfig
var popover = new bootstrap.Popover(element, {
popperConfig: function (defaultBsPopperConfig) {
// var newPopperConfig = {...}
// use defaultBsPopperConfig if needed...
// return newPopperConfig
}
})
Méthodes
Méthodes et transitions asynchrones
Toutes les méthodes API sont asynchrones et démarrent une transition . Ils reviennent à l'appelant dès que la transition est commencée mais avant qu'elle ne se termine . De plus, un appel de méthode sur un composant en transition sera ignoré .
Consultez notre documentation JavaScript pour plus d'informations.
Afficher
Révèle le popover d'un élément. Retourne à l'appelant avant que le popover n'ait été affiché (c'est-à-dire avant que l' shown.bs.popover
événement ne se produise). Ceci est considéré comme un déclenchement "manuel" du popover. Les popovers dont le titre et le contenu sont tous les deux de longueur nulle ne sont jamais affichés.
myPopover.show()
Cacher
Masque le popover d'un élément. Retourne à l'appelant avant que le popover n'ait été masqué (c'est-à-dire avant que l' hidden.bs.popover
événement ne se produise). Ceci est considéré comme un déclenchement "manuel" du popover.
myPopover.hide()
Basculer
Bascule le popover d'un élément. Revient à l'appelant avant que le popover n'ait été réellement affiché ou masqué (c'est-à-dire avant que l' événement shown.bs.popover
ou ne hidden.bs.popover
se produise). Ceci est considéré comme un déclenchement "manuel" du popover.
myPopover.toggle()
Disposer
Masque et détruit le popover d'un élément (supprime les données stockées sur l'élément DOM). Les popovers qui utilisent la délégation (créés à l'aide the selector
option) ne peuvent pas être détruits individuellement sur les éléments déclencheurs descendants.
myPopover.dispose()
Activer
Donne au popover d'un élément la possibilité d'être affiché. Les popovers sont activés par défaut.
myPopover.enable()
Désactiver
Supprime la possibilité d'afficher le popover d'un élément. Le popover ne pourra s'afficher que s'il est réactivé.
myPopover.disable()
ToggleEnabled
Active/désactive la possibilité d'afficher ou de masquer le popover d'un élément.
myPopover.toggleEnabled()
Mettre à jour
Met à jour la position du popover d'un élément.
myPopover.update()
getInstance
Méthode statique qui permet d'obtenir l'instance popover associée à un élément DOM
var exampleTriggerEl = document.getElementById('example')
var popover = bootstrap.Popover.getInstance(exampleTriggerEl) // Returns a Bootstrap popover instance
getOrCreateInstance
Méthode statique qui permet d'obtenir l'instance popover associée à un élément DOM, ou d'en créer une nouvelle au cas où elle n'aurait pas été initialisée
var exampleTriggerEl = document.getElementById('example')
var popover = bootstrap.Popover.getOrCreateInstance(exampleTriggerEl) // Returns a Bootstrap popover instance
Evènements
Type d'événement | Description |
---|---|
show.bs.popover | Cet événement se déclenche immédiatement lorsque la showméthode d'instance est appelée. |
shown.bs.popover | Cet événement est déclenché lorsque le popover a été rendu visible à l'utilisateur (il attendra que les transitions CSS soient terminées). |
hide.bs.popover | Cet événement est déclenché immédiatement lorsque la hide méthode d'instance a été appelée. |
hidden.bs.popover | Cet événement est déclenché lorsque le popover a fini d'être caché à l'utilisateur (il attendra que les transitions CSS soient terminées). |
inserted.bs.popover | Cet événement est déclenché après l' show.bs.popoverévénement lorsque le modèle de popover a été ajouté au DOM. |
var myPopoverTrigger = document.getElementById('myPopover')
myPopoverTrigger.addEventListener('hidden.bs.popover', function () {
// do something...
})