Popovers
Dokumentation og eksempler på tilføjelse af Bootstrap popovers, som dem der findes i iOS, til ethvert element på dit websted.
Oversigt
Ting at vide, når du bruger popover-plugin:
- Popovers er afhængige af 3. parts bibliotek Popper til positionering. Du skal inkludere popper.min.js før bootstrap.js eller bruge
bootstrap.bundle.min.js
/bootstrap.bundle.js
som indeholder Popper for at popovers kan virke! - Popovers kræver værktøjstip-plugin som en afhængighed.
- Hvis du bygger vores JavaScript fra kilden, kræver
util.js
det . - Popovers er opt-in af præstationsmæssige årsager, så du skal selv initialisere dem .
- Nul-længde
title
ogcontent
værdier vil aldrig vise en popover. - Angiv
container: 'body'
for at undgå gengivelse af problemer i mere komplekse komponenter (såsom vores inputgrupper, knapgrupper osv.). - At udløse popovers på skjulte elementer vil ikke fungere.
- Popovers for
.disabled
ellerdisabled
elementer skal udløses på et indpakningselement. - Når de udløses fra ankre, der ombrydes over flere linjer, vil popovers blive centreret mellem ankrenes samlede bredde. Brug
.text-nowrap
på dine<a>
s for at undgå denne adfærd. - Popovers skal skjules, før deres tilsvarende elementer er blevet fjernet fra DOM.
- Popovers kan udløses takket være et element inde i en skygge-DOM.
prefers-reduced-motion
medieforespørgslen. Se afsnittet om
reduceret bevægelse i vores tilgængelighedsdokumentation .
Fortsæt med at læse for at se, hvordan popovers fungerer med nogle eksempler.
Eksempel: Aktiver popovers overalt
En måde at initialisere alle popovers på en side ville være at vælge dem efter deres data-toggle
egenskab:
$(function () {
$('[data-toggle="popover"]').popover()
})
Eksempel: Brug af container
muligheden
Når du har nogle typografier på et overordnet element, der forstyrrer en popover, vil du gerne specificere en brugerdefineret container
, så popoverens HTML vises i dette element i stedet.
$(function () {
$('.example-popover').popover({
container: 'body'
})
})
Eksempel
<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>
Fire retninger
Fire muligheder er tilgængelige: top-, højre-, bund- og venstrejusteret.
<button type="button" class="btn btn-secondary" data-container="body" data-toggle="popover" data-placement="top" data-content="Top popover">
Popover on top
</button>
<button type="button" class="btn btn-secondary" data-container="body" data-toggle="popover" data-placement="right" data-content="Right popover">
Popover on right
</button>
<button type="button" class="btn btn-secondary" data-container="body" data-toggle="popover" data-placement="bottom" data-content="Bottom popover">
Popover on bottom
</button>
<button type="button" class="btn btn-secondary" data-container="body" data-toggle="popover" data-placement="left" data-content="Left popover">
Popover on left
</button>
Afvis ved næste klik
Brug focus
triggeren til at afvise popovers ved brugerens næste klik på et andet element end til/fra-elementet.
Specifik opmærkning påkrævet for at afvise-ved-næste-klik
For korrekt adfærd på tværs af browsere og på tværs af platforme skal du bruge <a>
tagget, ikke<button>
tagget, og du skal også inkludere en tabindex
attribut.
<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>
$('.popover-dismiss').popover({
trigger: 'focus'
})
Deaktiverede elementer
Elementer med disabled
attributten er ikke interaktive, hvilket betyder, at brugere ikke kan svæve eller klikke på dem for at udløse en popover (eller værktøjstip). Som en løsning vil du udløse popover fra en wrapper <div>
eller <span>
og tilsidesætte pointer-events
det deaktiverede element.
For deaktiverede popover-udløsere foretrækker du måske også data-trigger="hover"
, at popover-vinduet vises som øjeblikkelig visuel feedback til dine brugere, da de måske ikke forventer at klikke på et deaktiveret element.
<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>
Brug
Aktiver popovers via JavaScript:
$('#example').popover(options)
GPU acceleration
Popovers ser nogle gange slørede ud på Windows 10-enheder på grund af GPU-acceleration og en modificeret system-DPI. Løsningen for dette i v4 er at deaktivere GPU-acceleration efter behov på dine popovers.
Foreslået rettelse:
Popper.Defaults.modifiers.computeStyle.gpuAcceleration = !(window.devicePixelRatio < 1.5 && /Win/.test(navigator.platform))
Få popovers til at fungere for brugere af tastatur og hjælpemidler
For at tillade tastaturbrugere at aktivere dine popovers, bør du kun tilføje dem til HTML-elementer, der traditionelt er tastaturfokuserbare og interaktive (såsom links eller formularkontrolelementer). Selvom vilkårlige HTML-elementer (såsom <span>
s) kan gøres fokusbare ved at tilføje tabindex="0"
attributten, vil dette tilføje potentielt irriterende og forvirrende tabulatorstop på ikke-interaktive elementer for tastaturbrugere, og de fleste hjælpeteknologier annoncerer i øjeblikket ikke popoverens indhold i denne situation . Derudover skal du ikke stole udelukkende på hover
som udløseren for dine popovers, da dette vil gøre dem umulige at udløse for tastaturbrugere.
Selvom du kan indsætte rig, struktureret HTML i popovers med html
muligheden, anbefaler vi kraftigt, at du undgår at tilføje en overdreven mængde indhold. Den måde popovers fungerer på i øjeblikket er, at når de først er vist, er deres indhold bundet til triggerelementet med aria-describedby
attributten. Som et resultat vil hele popoverens indhold blive annonceret til hjælpeteknologibrugere som én lang, uafbrudt stream.
Derudover, mens det er muligt også at inkludere interaktive kontroller (såsom formularelementer eller links) i din popover (ved at tilføje disse elementer til whiteList
eller tilladte attributter og tags), skal du være opmærksom på, at popover i øjeblikket ikke administrerer tastaturets fokusrækkefølge. Når en tastaturbruger åbner en popover, forbliver fokus på det udløsende element, og da popover normalt ikke umiddelbart følger triggeren i dokumentets struktur, er der ingen garanti for, at man bevæger sig fremad/trykkerTABflytter en tastaturbruger ind i selve popoveren. Kort sagt, blot tilføjelse af interaktive kontroller til en popover vil sandsynligvis gøre disse kontroller utilgængelige/ubrugelige for tastaturbrugere og brugere af hjælpeteknologier, eller i det mindste skabe en ulogisk overordnet fokusrækkefølge. I disse tilfælde kan du overveje at bruge en modal dialog i stedet.
Muligheder
Indstillinger kan videregives via dataattributter eller JavaScript. For dataattributter skal du tilføje indstillingsnavnet til data-
, som i data-animation=""
.
sanitize
,
sanitizeFn
og
whiteList
ikke leveres ved hjælp af dataattributter.
Navn | Type | Standard | Beskrivelse |
---|---|---|---|
animation | boolesk | rigtigt | Anvend en CSS-fade-overgang til popoveren |
beholder | streng | element | falsk | falsk | Føjer popover til et bestemt element. Eksempel: |
indhold | streng | element | fungere | '' | Standardindholdsværdi, hvis Hvis en funktion er givet, vil den blive kaldt med dens |
forsinke | nummer | objekt | 0 | Forsinket visning og skjulning af popover (ms) - gælder ikke for manuel triggertype Hvis et nummer er angivet, anvendes forsinkelse på både skjul/show Objektstrukturen er: |
html | boolesk | falsk | Indsæt HTML i popoveren. Hvis falsk, vil jQuerys text metode blive brugt til at indsætte indhold i DOM. Brug tekst, hvis du er bekymret for XSS-angreb. |
placering | streng | fungere | 'ret' | Sådan placeres popover - auto | top | nederst | venstre | ret. Når en funktion bruges til at bestemme placeringen, kaldes den med popover DOM-knuden som dets første argument og det udløsende element DOM-noden som dens anden. Konteksten |
vælger | streng | falsk | falsk | Hvis der er angivet en vælger, vil popover-objekter blive uddelegeret til de angivne mål. I praksis bruges dette til at gøre det muligt for dynamisk HTML-indhold at tilføje popovers. Se dette og et informativt eksempel . |
skabelon | snor | '<div class="popover" role="tooltip"><div class="arrow"></div><h3 class="popover-header"></h3><div class="popover-body"></div></div>' |
Base HTML til brug ved oprettelse af popover. Popover'erne Popover'erne
Det yderste indpakningselement skal have |
titel | streng | element | fungere | '' | Standard titelværdi, hvis Hvis en funktion er givet, vil den blive kaldt med dens |
udløser | snor | 'klik' | Hvordan popover udløses - klik | svæv | fokus | brugervejledning. Du kan passere flere triggere; adskille dem med et mellemrum. manual kan ikke kombineres med nogen anden trigger. |
offset | nummer | snor | 0 | Forskydning af popover i forhold til dets mål. For mere information henvises til Poppers offset-dokumenter . |
fallbackPlacering | streng | array | 'flip' | Tillad at angive, hvilken position Popper vil bruge ved fallback. For mere information henvises til Poppers adfærdsdokumentation |
customClass | streng | fungere | '' | Tilføj klasser til popover, når det vises. Bemærk, at disse klasser vil blive tilføjet ud over de klasser, der er angivet i skabelonen. For at tilføje flere klasser skal du adskille dem med mellemrum: Du kan også sende en funktion, der skal returnere en enkelt streng, der indeholder yderligere klassenavne. |
grænse | streng | element | 'scrollParent' | Overløbsbegrænsningsgrænse for popover. Accepterer værdierne for 'viewport' , 'window' , 'scrollParent' eller en HTMLElement-reference (kun JavaScript). For mere information henvises til Poppers preventOverflow-dokumenter . |
desinficere | boolesk | rigtigt | Aktiver eller deaktiver desinficering. Hvis aktiveret 'template' , 'content' og 'title' muligheder vil blive renset. Se afsnittet om desinfektion i vores JavaScript-dokumentation . |
hvidliste | objekt | Standard værdi | Objekt som indeholder tilladte attributter og tags |
sanitizeFn | null | fungere | nul | Her kan du selv levere din desinficeringsfunktion. Dette kan være nyttigt, hvis du foretrækker at bruge et dedikeret bibliotek til at udføre desinficering. |
popperConfig | null | objekt | nul | For at ændre Bootstraps standard Popper -konfiguration, se Poppers konfiguration |
Dataattributter for individuelle popovers
Valgmuligheder for individuelle popovers kan alternativt specificeres ved brug af dataattributter, som forklaret ovenfor.
Metoder
Asynkrone metoder og overgange
Alle API - metoder er asynkrone og starter en overgang . De vender tilbage til den, der ringer, så snart overgangen er startet, men før den slutter . Derudover vil et metodekald på en overgangskomponent blive ignoreret .
$().popover(options)
Initialiserer popovers for en elementsamling.
.popover('show')
Afslører et elements popover. Vender tilbage til den, der ringer, før popover-vinduet rent faktisk er blevet vist (dvs. før shown.bs.popover
hændelsen indtræffer). Dette betragtes som en "manuel" udløsning af popover. Popovers, hvis titel og indhold begge er nul-længde, vises aldrig.
$('#element').popover('show')
.popover('hide')
Skjuler et elements popover. Vender tilbage til den, der ringer, før popover faktisk er blevet skjult (dvs. før hidden.bs.popover
hændelsen indtræffer). Dette betragtes som en "manuel" udløsning af popover.
$('#element').popover('hide')
.popover('toggle')
Skifter et elements popover. Vender tilbage til den, der ringer, før pop-over faktisk er blevet vist eller skjult (dvs. før hændelsen shown.bs.popover
eller hidden.bs.popover
indtræffer). Dette betragtes som en "manuel" udløsning af popover.
$('#element').popover('toggle')
.popover('dispose')
Skjuler og ødelægger et elements popover. Popovers, der bruger delegering (som oprettes ved hjælp af selector
muligheden ), kan ikke individuelt destrueres på descendant trigger-elementer.
$('#element').popover('dispose')
.popover('enable')
Giver et elements popover mulighed for at blive vist. Popovers er aktiveret som standard.
$('#element').popover('enable')
.popover('disable')
Fjerner muligheden for, at et elements popover vises. Popover vil kun kunne vises, hvis det er genaktiveret.
$('#element').popover('disable')
.popover('toggleEnabled')
Skifter muligheden for, at et elements popover vises eller skjules.
$('#element').popover('toggleEnabled')
.popover('update')
Opdaterer placeringen af et elements popover.
$('#element').popover('update')
Begivenheder
Begivenhedstype | Beskrivelse |
---|---|
show.bs.popover | Denne hændelse udløses med det samme, når show instansmetoden kaldes. |
vist.bs.popover | Denne hændelse udløses, når popoveren er gjort synlig for brugeren (vil vente på, at CSS-overgange er fuldført). |
hide.bs.popover | Denne hændelse udløses straks, når hide instansmetoden er blevet kaldt. |
skjult.bs.popover | Denne hændelse udløses, når popoveren er færdig med at blive skjult for brugeren (vil vente på, at CSS-overgange er fuldført). |
indsat.bs.popover | Denne hændelse udløses efter show.bs.popover hændelsen, når popover-skabelonen er blevet tilføjet til DOM. |
$('#myPopover').on('hidden.bs.popover', function () {
// do something...
})