Popovers
Dokumentacija i primjeri za dodavanje Bootstrap skočnih prozora, poput onih koji se nalaze u iOS-u, bilo kojem elementu na vašoj web-lokaciji.
Pregled
Stvari koje treba znati kada koristite popover dodatak:
- Popovers se za pozicioniranje oslanjaju na biblioteku treće strane Popper.js . Morate uključiti popper.min.js prije bootstrap.js ili koristiti
bootstrap.bundle.min.js
/bootstrap.bundle.js
koji sadrži Popper.js kako bi popoveri radili! - Popovi zahtijevaju plugin tooltip kao ovisnost.
- Ako gradite naš JavaScript iz izvora, to zahtijeva
util.js
. - Popoveri su opt-in zbog performansi, pa ih morate sami pokrenuti .
- Nulta duljina
title
icontent
vrijednosti nikada neće prikazati skočni prikaz. - Navedite
container: 'body'
kako biste izbjegli probleme s generiranjem u složenijim komponentama (poput naših ulaznih grupa, grupa gumba itd.). - Pokretanje skočnih prozora na skrivenim elementima neće raditi.
- Skočni prozori za elemente
.disabled
ilidisabled
moraju se pokrenuti na elementu omotača. - Kada se pokreću iz sidrišta koja se prelamaju preko više linija, skočni prozori bit će centrirani između ukupne širine sidrišta. Koristite
.text-nowrap
na svom<a>
s kako biste izbjegli ovakvo ponašanje. - Skočni prozori moraju biti skriveni prije nego što se njihovi odgovarajući elementi uklone iz DOM-a.
- Popoveri se mogu pokrenuti zahvaljujući elementu unutar DOM-a u sjeni.
Učinak animacije ove komponente ovisi o prefers-reduced-motion
medijskom upitu. Pogledajte odjeljak smanjenog kretanja u našoj dokumentaciji o pristupačnosti .
Nastavite čitati da vidite kako skočni prozori funkcioniraju s nekim primjerima.
Primjer: Omogućite skočne prozore posvuda
Jedan od načina da inicijalizirate sve skočne prozore na stranici bio bi da ih odaberete prema njihovom data-toggle
atributu:
Primjer: Korištenje container
opcije
Kada imate neke stilove na nadređenom elementu koji ometaju skočni prozor, trebali biste navesti prilagođeni container
tako da se HTML skočnog prozora pojavljuje unutar tog elementa.
Primjer
Četiri smjera
Dostupne su četiri opcije: gore, desno, dolje i lijevo poravnato.
Odbaci pri sljedećem kliku
Upotrijebite focus
okidač za odbacivanje skočnih prozora pri sljedećem korisnikovom kliku na element različit od preklopnog elementa.
Za odbacivanje pri sljedećem kliku potrebna je posebna oznaka
Za ispravno ponašanje između preglednika i platformi, morate koristiti <a>
oznaku, a ne oznaku <button>
, a također morate uključiti tabindex
atribut.
Onemogućeni elementi
Elementi s disabled
atributom nisu interaktivni, što znači da korisnici ne mogu lebdjeti pokazivačem ili kliknuti na njih da bi pokrenuli skočni prozor (ili opis). Kao zaobilazno rješenje, htjet ćete pokrenuti skočni prozor iz omotača <div>
ili <span>
nadjačati pointer-events
element na onemogućenom elementu.
Za onemogućene okidače skočnog prozora možda biste radije željeli data-trigger="hover"
da se skočni prozor pojavi kao neposredna vizualna povratna informacija vašim korisnicima jer možda neće očekivati da će kliknuti na onemogućeni element.
Korištenje
Omogući skočne prozore putem JavaScripta:
Mogućnosti
Opcije se mogu proslijediti putem atributa podataka ili JavaScripta. Za atribute podataka dodajte naziv opcije u data-
, kao u data-animation=""
.
Ime | Tip | Zadano | Opis |
---|---|---|---|
animacija | Booleov | pravi | Primijenite CSS fade prijelaz na skočni prozor |
spremnik | niz | element | lažno | lažno | Dodaje skočni prozor određenom elementu. Primjer: |
sadržaj | niz | element | funkcija | '' | Zadana vrijednost sadržaja ako Ako je dana funkcija, bit će pozvana s |
odgoditi | broj | objekt | 0 | Odgoda prikazivanja i skrivanja skočnog prozora (ms) - ne odnosi se na vrstu ručnog okidača Ako je naveden broj, odgoda se primjenjuje na skrivanje/prikazivanje Struktura objekta je: |
html | Booleov | lažno | Umetnite HTML u skočni prozor. Ako je false, jQueryjeva text metoda koristit će se za umetanje sadržaja u DOM. Upotrijebite tekst ako ste zabrinuti zbog XSS napada. |
plasman | niz | funkcija | 'pravo' | Kako postaviti popover - automatski | vrh | dno | lijevo | pravo. Kada se funkcija koristi za određivanje položaja, poziva se s skočnim DOM čvorom kao prvim argumentom i DOM čvorom pokretačkog elementa kao drugim. Kontekst |
selektor | niz | lažno | lažno | Ako je selektor osiguran, skočni objekti bit će delegirani navedenim ciljevima. U praksi se ovo koristi za omogućavanje dodavanja skočnih prozora za dinamički HTML sadržaj. Pogledajte ovo i informativan primjer . |
šablona | niz | '<div class="popover" role="tooltip"><div class="arrow"></div><h3 class="popover-header"></h3><div class="popover-body"></div></div>' |
Osnovni HTML za korištenje pri stvaranju skočnog prozora. Popover Popover
Najudaljeniji element omotača trebao bi imati |
titula | niz | element | funkcija | '' | Zadana vrijednost naslova ako Ako je dana funkcija, bit će pozvana s |
okidač | niz | 'klik' | Kako se pokreće popover - kliknite | lebdjeti | fokus | priručnik. Možete proći više okidača; odvojite ih razmakom. manual ne može se kombinirati ni s jednim drugim okidačem. |
pomaknuti | broj | niz | 0 | Pomak popover-a u odnosu na cilj. Za više informacija pogledajte Popper.js offset dokumente . |
zamjenaPlacement | niz | niz | 'okrenuti' | Omogućuje određivanje pozicije koju će Popper koristiti pri povratku. Za više informacija pogledajte dokumente o ponašanju Popper.js |
granica | niz | element | 'scrollParent' | Granica ograničenja prelijevanja skočnog prozora. Prihvaća vrijednosti 'viewport' , 'window' , 'scrollParent' ili HTMLElement reference (samo JavaScript). Za više informacija pogledajte Popper.js's preventOverflow dokumente . |
Atributi podataka za pojedinačne skočne prozore
Opcije za pojedinačne skočne prozore mogu se alternativno specificirati upotrebom atributa podataka, kao što je gore objašnjeno.
Metode
Asinkrone metode i prijelazi
Sve API metode su asinkrone i pokreću prijelaz . Vraćaju se pozivatelju čim prijelaz započne, ali prije nego što završi . Osim toga, poziv metode na prijelaznoj komponenti bit će zanemaren .
Pogledajte našu JavaScript dokumentaciju za više informacija .
$().popover(options)
Inicijalizira skočne prozore za zbirku elemenata.
.popover('show')
Otkriva popover elementa. Vraća se pozivatelju prije nego što se popover stvarno prikaže (tj. prije nego što se shown.bs.popover
događaj dogodi). Ovo se smatra "ručnim" pokretanjem popover-a. Skočni prozori čiji su i naslov i sadržaj nulte duljine nikad se ne prikazuju.
.popover('hide')
Skriva skočni prozor elementa. Vraća se pozivatelju prije nego što je popover zapravo skriven (tj. prije nego što se hidden.bs.popover
događaj dogodi). Ovo se smatra "ručnim" pokretanjem popover-a.
.popover('toggle')
Isključuje skočni prozor elementa. Vraća se pozivatelju prije nego što se popover stvarno prikaže ili sakrije (tj. prije nego što se dogodi događaj shown.bs.popover
ili ). hidden.bs.popover
Ovo se smatra "ručnim" pokretanjem popover-a.
.popover('dispose')
Skriva i uništava popover elementa. Popoveri koji koriste delegiranje (koji se stvaraju pomoću opcije selector
) ne mogu se pojedinačno uništiti na okidačkim elementima potomcima.
.popover('enable')
Daje mogućnost prikazivanja skočnog prozora elementa. Skočni prozori omogućeni su prema zadanim postavkama.
.popover('disable')
Uklanja mogućnost prikazivanja skočnog prozora elementa. Popover će se moći prikazati samo ako je ponovno omogućen.
.popover('toggleEnabled')
Isključuje mogućnost prikazivanja ili sakrivanja skočnog prozora elementa.
.popover('update')
Ažurira položaj skočnog prozora elementa.
Događaji
Vrsta događaja | Opis |
---|---|
pokazati.bs.popover | Ovaj događaj aktivira se odmah kada show se pozove metoda instance. |
prikazano.bs.popover | Ovaj se događaj pokreće kada je popover vidljiv korisniku (pričekat će se da se CSS prijelazi završe). |
sakriti.bs.popover | Ovaj se događaj aktivira odmah nakon hide pozivanja metode instance. |
skriven.bs.popover | Ovaj se događaj pokreće kada popover više nije skriven od korisnika (pričekat će se da se dovrše CSS prijelazi). |
umetnuto.bs.popover | Ovaj se događaj pokreće nakon show.bs.popover događaja kada je skočni predložak dodan u DOM. |