Popisy
Dokumentácia a príklady na pridávanie vlastných popisov Bootstrap s CSS a JavaScript pomocou CSS3 pre animácie a dátové atribúty pre lokálne ukladanie titulkov.
Čo by ste mali vedieť pri používaní doplnku tooltip:
- Pri určovaní polohy sa popisy spoliehajú na knižnicu Popper.js tretej strany . Aby popisky fungovali, musíte pred bootstrap.js zahrnúť popper.min.js alebo použiť
bootstrap.bundle.min.js
/bootstrap.bundle.js
ktorý obsahuje Popper.js! - Ak vytvárate náš JavaScript zo zdroja, vyžaduje
util.js
to . - Popisy sú aktivované z dôvodov výkonu, takže ich musíte inicializovať sami .
- Popisy s názvami s nulovou dĺžkou sa nikdy nezobrazujú.
- Špecifikujte
container: 'body'
, aby ste sa vyhli problémom s vykresľovaním v zložitejších komponentoch (ako sú naše vstupné skupiny, skupiny tlačidiel atď.). - Spúšťanie popisov na skrytých prvkoch nebude fungovať.
- Popisy prvkov
.disabled
alebodisabled
prvkov musia byť spustené na prvku obalu. - Pri spustení z hypertextových odkazov, ktoré presahujú viacero riadkov, budú popisy nástrojov vycentrované. Použite
white-space: nowrap;
na<a>
s, aby ste sa vyhli tomuto správaniu. - Popisy nástrojov musia byť skryté pred odstránením príslušných prvkov z modelu DOM.
Máš to všetko? Skvelé, pozrime sa, ako fungujú s niekoľkými príkladmi.
Jedným zo spôsobov, ako inicializovať všetky popisy na stránke, je vybrať ich podľa ich data-toggle
atribútu:
Umiestnením kurzora myši na odkazy nižšie zobrazíte popisy:
Tesné nohavice ďalšej úrovne keffiyeh , o ktorých ste pravdepodobne ešte nepočuli. Photo booth brada raw denim kníhtlač vegan messenger bag stumptown. 8-bitové americké oblečenie z farmy na stôl seitan, mcsweeney's fixie udržateľná quinoa má vinylovú chambray z froté richardson. Beard stumptown, cardigany banh mi lomo thundercats. Tofu biodiesel williamsburg marfa, štyri loko mcsweeney's cleanse vegan chambray. Skutočne ironický remeselník bez ohľadu na klávesnicu, scénár z farmy na stôl Banky Austin twitter zvládnuť freegan cred raw denim single-origin coffee viral.
Umiestnením kurzora myši na tlačidlá nižšie zobrazíte štyri smery popisov: hore, vpravo, dole a vľavo.
A s pridaným vlastným HTML:
Doplnok tooltip generuje obsah a značky na požiadanie a v predvolenom nastavení umiestňuje popisky za ich spúšťací prvok.
Spustite popis pomocou JavaScriptu:
Pretečenie auto
ascroll
Pozícia popisku sa pokúsi automaticky zmeniť, keď nadradený kontajner má overflow: auto
alebo sa overflow: scroll
páči nášmu .table-responsive
, ale stále si zachováva pôvodné umiestnenie. Ak to chcete vyriešiť, nastavte túto boundary
možnosť na inú ako predvolenú hodnotu, 'scrollParent'
napríklad 'window'
:
Požadované označenie pre popis je iba data
atribút a title
na elemente HTML chcete mať popis. Vygenerované označenie popisku je pomerne jednoduché, aj keď vyžaduje pozíciu (v predvolenom nastavení top
ju doplnok nastaví na hodnotu).
Zabezpečte, aby popisy fungovali pre používateľov klávesnice a asistenčných technológií
Popisy nástrojov by ste mali pridávať len k prvkom HTML, ktoré sú tradične zamerané na klávesnicu a sú interaktívne (napríklad odkazy alebo ovládacie prvky formulárov). Hoci ľubovoľné prvky HTML (napríklad <span>
s) môžu byť zaostriteľné pridaním tabindex="0"
atribútu, používateľom klávesnice to pridajú potenciálne nepríjemné a mätúce zarážky tabulátora na neinteraktívnych prvkoch. Navyše väčšina asistenčných technológií v súčasnosti v tejto situácii neoznamuje popis.
Okrem toho sa nespoliehajte iba na hover
spúšťač pre váš popis, pretože to znemožní spustenie vašich popisov pre používateľov klávesnice.
Prvky s disabled
atribútom nie sú interaktívne, čo znamená, že používatelia na ne nemôžu zaostriť, umiestniť kurzor myši alebo na ne kliknúť, aby vyvolali popis (alebo kontextové okno). Ako riešenie budete chcieť spustiť popis nástroja z obalu <div>
alebo <span>
, ideálne tak, aby bolo možné zamerať sa na klávesnicu pomocou tabindex="0"
, a prepísať pointer-events
prvok na zakázanom prvku.
Možnosti môžu byť odovzdané prostredníctvom dátových atribútov alebo JavaScriptu. Pre atribúty údajov pripojte názov voľby k data-
, ako v data-animation=""
.
názov | Typ | Predvolené | Popis |
---|---|---|---|
animácie | boolovská hodnota | pravda | Použite prechod zoslabovania CSS na popis |
kontajner | reťazec | prvok | falošné | falošné | Pridá popis ku konkrétnemu prvku. Príklad: |
meškanie | číslo | objekt | 0 | Oneskorenie zobrazenia a skrytia tooltipu (ms) – netýka sa manuálneho typu spúšťania Ak je zadané číslo, oneskorenie sa použije na skrytie/zobrazenie Štruktúra objektu je: |
html | boolovská hodnota | falošné | Povoliť HTML v popise. Ak je pravda, značky HTML v popise Ak sa obávate útokov XSS, použite text. |
umiestnenie | reťazec | funkciu | 'top' | Ako umiestniť popis – auto | hore | dole | vľavo | správny. Keď sa na určenie umiestnenia použije funkcia, volá sa s popisom uzla DOM ako jej prvým argumentom a spúšťacím prvkom uzlom DOM ako jej druhým. Kontext |
selektor | reťazec | falošné | falošné | Ak je k dispozícii selektor, objekty popisov budú delegované na zadané ciele. V praxi sa to používa na umožnenie pridávania vyskakovacích okien do dynamického obsahu HTML. Pozrite si tento a informatívny príklad . |
šablóna | reťazec | '<div class="tooltip" role="tooltip"><div class="arrow"></div><div class="tooltip-inner"></div></div>' |
Základný kód HTML, ktorý sa má použiť pri vytváraní popisu. Popis
Prvok vonkajšieho obalu by mal mať |
titul | reťazec | prvok | funkciu | '' | Predvolená hodnota názvu, ak Ak je zadaná funkcia, zavolá sa so svojou |
spúšťač | reťazec | 'hover focus' | Ako sa spúšťa popis – kliknite | vznášať sa | zameranie | Manuálny. Môžete prejsť viacerými spúšťačmi; oddeľte ich medzerou.
|
offset | číslo | reťazec | 0 | Odsadenie popisku vzhľadom na jeho cieľ. Ďalšie informácie nájdete v dokumentoch offsetu Popper.js . |
záložné umiestnenie | reťazec | pole | 'flip' | Povoľte určiť, ktorú pozíciu použije Popper pri núdzovom postupe. Ďalšie informácie nájdete v dokumentoch o správaní Popper.js |
hranica | reťazec | prvok | 'scrollParent' | Hranica obmedzenia pretečenia popisku. Prijíma hodnoty 'viewport' , 'window' , 'scrollParent' alebo odkaz HTMLElement (iba JavaScript). Ďalšie informácie nájdete v dokumentoch preventOverflow Popper.js . |
Atribúty údajov pre jednotlivé popisy
Možnosti pre jednotlivé popisy nástrojov možno alternatívne špecifikovať pomocou atribútov údajov, ako je vysvetlené vyššie.
Asynchrónne metódy a prechody
Všetky metódy API sú asynchrónne a spúšťajú prechod . Vrátia sa k volajúcemu hneď po spustení prechodu, ale skôr, ako sa skončí . Okrem toho bude volanie metódy na prechodovom komponente ignorované .
Ku kolekcii prvkov pripojí popisovač.
Zobrazí popis prvku. Vráti sa k volajúcemu skôr, ako sa skutočne zobrazil popis (tj pred výskytom shown.bs.tooltip
udalosti). Toto sa považuje za „manuálne“ spustenie popisku. Popisy s názvami s nulovou dĺžkou sa nikdy nezobrazujú.
Skryje popis prvku. Vráti sa k volajúcemu skôr, ako bol popis skutočne skrytý (tj pred výskytom hidden.bs.tooltip
udalosti). Toto sa považuje za „manuálne“ spustenie popisku.
Prepína popis prvku. Vráti sa k volajúcemu skôr, než sa popis skutočne zobrazí alebo skryje (tj predtým, ako nastane udalosť shown.bs.tooltip
alebo ). hidden.bs.tooltip
Toto sa považuje za „manuálne“ spustenie popisku.
Skryje a zničí popis prvku. Popisy, ktoré používajú delegovanie (ktoré sú vytvorené pomocou voľby ) selector
, nemožno jednotlivo zničiť na podradených spúšťacích prvkoch.
Umožňuje zobraziť popis prvku. Popisy sú predvolene povolené.
Odstráni možnosť zobrazenia popisu prvku. Popis bude možné zobraziť iba vtedy, ak bude znova povolený.
Prepína možnosť zobrazenia alebo skrytia popisku prvku.
Aktualizuje polohu popisku prvku.
Typ udalosti | Popis |
---|---|
zobraziť.bs.popis | Táto udalosť sa spustí okamžite pri show volaní metódy inštancie. |
zobrazený.bs.tip | Táto udalosť sa spustí, keď sa popis zobrazí používateľovi (bude čakať na dokončenie prechodov CSS). |
hide.bs.tooltip | Táto udalosť sa spustí okamžite po hide zavolaní metódy inštancie. |
skrytý.bs.tip | Táto udalosť sa spustí, keď skončí skrytie popisu pred používateľom (bude čakať na dokončenie prechodov CSS). |
vložený.bs.tip | Táto udalosť sa spustí po show.bs.tooltip udalosti, keď bola šablóna popisu pridaná do modelu DOM. |