Popovers
Dokumentaatio ja esimerkkejä Bootstrap-ponnahdusikkunoiden, kuten iOS:n, lisäämisestä mihin tahansa sivustosi elementtiin.
Yleiskatsaus
Tietoja ponnahduslaajennusta käytettäessä:
- Popoverit luottavat paikannukseen kolmannen osapuolen kirjaston Popperiin . Sinun tulee lisätä popper.min.js ennen bootstrap.js:ää tai käyttää
bootstrap.bundle.min.js
/bootstrap.bundle.js
joka sisältää Popperin, jotta ponnahdusikkunat toimivat! - Ponnahdusikkunat vaativat työkaluvihje-laajennuksen riippuvuutena.
- Jos rakennat JavaScript-koodiamme lähteestä, se vaatii
util.js
. - Ponnahdusikkunat ovat käytössä suorituskykysyistä, joten sinun on alustettava ne itse .
- Nollapituus
title
jacontent
arvot eivät koskaan näytä ponnahdusikkunaa. - Määritä
container: 'body'
, jotta vältät hahmonnusongelmia monimutkaisemmissa osissa (kuten syöttöryhmämme, painikeryhmämme jne.). - Ponnahdusikkunoiden käynnistäminen piilotetuissa elementeissä ei toimi.
.disabled
Ponnahdusikkunat elementeille taidisabled
elementeille on käynnistettävä kääreelementissä .- Kun ponnahdusikkuna laukaistaan ankkureista, jotka kietoutuvat useille viivoille, ne keskitetään ankkurien kokonaisleveyden väliin. Vältä tämä käyttäytyminen käyttämällä sitä
.text-nowrap
.<a>
- Ponnahdusikkunat on piilotettava ennen kuin niitä vastaavat elementit on poistettu DOM:sta.
- Ponnahdusikkunat voidaan laukaista varjo-DOM:n sisällä olevan elementin ansiosta.
prefers-reduced-motion
mediakyselystä. Katso
esteettömyysdokumentaation osio liikkeen vähentämisestä .
Jatka lukemista nähdäksesi, kuinka ponnahdusikkunat toimivat joidenkin esimerkkien avulla.
Esimerkki: Ota ponnahdusikkunat käyttöön kaikkialla
Yksi tapa alustaa kaikki ponnahdusikkunat sivulla on valita ne niiden data-toggle
määritteen perusteella:
$(function () {
$('[data-toggle="popover"]').popover()
})
Esimerkki: container
vaihtoehdon käyttäminen
Jos pääelementissä on tyylejä, jotka häiritsevät ponnahdusikkunaa, haluat määrittää mukautetun container
ponnahdusikkunan HTML-koodin, joka näkyy sen sijaan kyseisessä elementissä.
$(function () {
$('.example-popover').popover({
container: 'body'
})
})
Esimerkki
<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>
Neljä suuntaa
Käytettävissä on neljä vaihtoehtoa: ylä-, oikea-, ala- ja vasemmalle tasattuna.
<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>
Hylkää seuraavalla klikkauksella
Käytä focus
liipaisinta hylätäksesi ponnahdusikkunat, kun käyttäjä seuraavaan napsauttaa eri elementtiä kuin vaihtoelementtiä.
Erityinen merkintä vaaditaan hylkäämiseen seuraavan napsautuksen yhteydessä
Jotta selain- ja alustojen välinen toiminta onnistuisi oikein, sinun on käytettävä tunnistetta <a>
tagin sijaan<button>
, ja sinun on myös sisällytettävä tabindex
attribuutti.
<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'
})
Poistetut elementit
Attribuutilla varustetut elementit disabled
eivät ole vuorovaikutteisia, mikä tarkoittaa, että käyttäjät eivät voi viedä hiiren osoitinta tai napsauttaa niitä käynnistääkseen ponnahdusikkunan (tai työkaluvihjeen). Kiertotavana voit käynnistää ponnahdusikkunan kääreestä <div>
tai <span>
ohittaa pointer-events
käytöstä poistetun elementin.
Jos ponnahdusikkuna käynnistyy pois käytöstä, voit myös haluta data-trigger="hover"
, että ponnahdusikkuna näkyy käyttäjillesi välittömänä visuaalisena palautteena, koska he eivät ehkä odota napsauttavansa käytöstä poistettua elementtiä.
<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>
Käyttö
Ota ponnahdusikkunat käyttöön JavaScriptin kautta:
$('#example').popover(options)
GPU-kiihdytys
Ponnahdusikkunat näyttävät joskus epäselviltä Windows 10 -laitteissa GPU-kiihdytyksen ja muokatun järjestelmän DPI:n vuoksi. Kiertotapa tähän v4:ssä on poistaa GPU-kiihdytys käytöstä ponnahdusikkunoissasi tarpeen mukaan.
Korjausehdotus:
Popper.Defaults.modifiers.computeStyle.gpuAcceleration = !(window.devicePixelRatio < 1.5 && /Win/.test(navigator.platform))
Ponnahdusikkunoiden saaminen toimimaan näppäimistön ja aputekniikan käyttäjille
Jotta näppäimistön käyttäjät voivat aktivoida ponnahdusikkunasi, sinun tulee lisätä ne vain sellaisiin HTML-elementteihin, jotka ovat perinteisesti kohdistettavissa näppäimistöön ja ovat interaktiivisia (kuten linkit tai lomakeohjaimet). Vaikka mielivaltaiset HTML-elementit (kuten <span>
s) voidaan tehdä tarkennettavissa lisäämällä tabindex="0"
attribuutti, tämä lisää mahdollisesti ärsyttäviä ja hämmentäviä sarkaimia ei-interaktiivisiin elementteihin näppäimistön käyttäjille, ja useimmat aputekniikat eivät tällä hetkellä ilmoita ponnahdusikkunan sisältöä tässä tilanteessa. . Älä myöskään luota siihen hover
, että se on vain ponnahdusikkunoiden laukaisin, koska tämä tekee niistä mahdotonta laukaista näppäimistön käyttäjille.
Vaikka voit lisätä monipuolista, jäsenneltyä HTML-koodia ponnahdusikkunoihin tällä html
vaihtoehdolla, suosittelemme, että vältät liiallisen sisällön lisäämisen. Ponnahdusikkunat toimivat tällä hetkellä siten, että kun ne näytetään, niiden sisältö on sidottu trigger-elementtiin aria-describedby
määritteellä. Tämän seurauksena koko popoverin sisältö julkistetaan aputekniikan käyttäjille yhtenä pitkänä, keskeytymättömänä streamina.
Lisäksi, vaikka on mahdollista sisällyttää myös interaktiivisia ohjaimia (kuten lomakeelementtejä tai linkkejä) ponnahdusikkunaan (lisäämällä nämä elementit whiteList
sallittuihin määritteisiin ja tunnisteisiin), huomaa, että tällä hetkellä ponnahdusikkuna ei hallitse näppäimistön kohdistusjärjestystä. Kun näppäimistön käyttäjä avaa ponnahdusikkunan, kohdistus pysyy laukaisevassa elementissä, ja koska ponnahdusikkuna ei yleensä seuraa välittömästi liipaisinta dokumentin rakenteessa, ei ole takeita siitä, että eteenpäin/painaminenTABsiirtää näppäimistön käyttäjän itse ponnahdusikkunaan. Lyhyesti sanottuna, pelkkä interaktiivisten säätimien lisääminen ponnahdusikkunaan tekee näistä säätimistä todennäköisesti saavuttamattomia/käyttökelvottomiksi näppäimistön käyttäjille ja aputekniikoiden käyttäjille, tai ainakin muodostaa epäloogisen yleisen tarkennusjärjestyksen. Harkitse näissä tapauksissa modaalisen valintaikkunan käyttöä.
Vaihtoehdot
Vaihtoehdot voidaan välittää tietomääritteiden tai JavaScriptin kautta. Liitä tietomääritteissä vaihtoehdon nimi kohtaan data-
, kuten kohdassa data-animation=""
.
sanitize
,
sanitizeFn
ja
whiteList
-asetuksia ei voida toimittaa dataattribuuttien avulla.
Nimi | Tyyppi | Oletus | Kuvaus |
---|---|---|---|
animaatio | boolean | totta | Käytä ponnahdusikkunassa CSS-häivytystä |
kontti | merkkijono | elementti | väärä | väärä | Liittää ponnahdusikkunan tiettyyn elementtiin. Esimerkki: |
sisältö | merkkijono | elementti | toiminto | '' | Sisällön oletusarvo, jos Jos funktio on annettu, sitä kutsutaan ja sen |
viive | numero | esine | 0 | Ponnahdusikkunan näyttämisen ja piilottamisen viive (ms) - ei koske manuaalista laukaisutyyppiä Jos numero annetaan, viivettä käytetään molempiin piilottamiseen/näyttöön Objektin rakenne on: |
html | boolean | väärä | Lisää HTML ponnahdusikkunaan. Jos epätosi, jQueryn text menetelmää käytetään sisällön lisäämiseen DOM:iin. Käytä tekstiä, jos olet huolissasi XSS-hyökkäyksistä. |
sijoitus | merkkijono | toiminto | 'oikein' | Ponnahdusikkunan sijoittaminen - auto | alkuun | pohja | vasemmalle | oikein. Kun funktiota käytetään sijoittelun määrittämiseen, sitä kutsutaan popover DOM-solmulla ensimmäisenä argumenttina ja liipaisuelementin DOM-solmun toisena argumenttina. Konteksti |
valitsin | merkkijono | väärä | väärä | Jos valitsin on käytössä, ponnahdusikkunaobjektit delegoidaan määritetyille kohteille. Käytännössä tätä käytetään mahdollistamaan ponnahdusikkunoiden lisääminen dynaamiseen HTML-sisältöön. Katso tämä ja informatiivinen esimerkki . |
sapluuna | merkkijono | '<div class="popover" role="tooltip"><div class="arrow"></div><h3 class="popover-header"></h3><div class="popover-body"></div></div>' |
Ponnahdusikkunaa luotaessa käytettävä perus-HTML. Popover's Popover's
Uloimmalla kääreelementillä tulee olla |
otsikko | merkkijono | elementti | toiminto | '' | Otsikon oletusarvo, jos Jos funktio on annettu, sitä kutsutaan ja sen |
laukaista | merkkijono | 'klikkaus' | Kuinka ponnahdusikkuna käynnistyy - napsauta | leijua | keskittyä | manuaalinen. Voit läpäistä useita laukaisimia; erota ne välilyönnillä. manual ei voida yhdistää mihinkään muuhun laukaisuun. |
offset | numero | merkkijono | 0 | Ponnahdusikkunan poikkeama suhteessa kohteeseen. Lisätietoja on Popperin offset-dokumenteissa . |
varasijoitus | merkkijono | joukko | 'voltti' | Salli määrittää, mitä asentoa Popper käyttää varautumisessa. Lisätietoja on Popperin käyttäytymisdokumenteissa |
custom Class | merkkijono | toiminto | '' | Lisää luokat ponnahdusikkunaan, kun se näytetään. Huomaa, että nämä luokat lisätään mallissa määritettyjen luokkien lisäksi. Voit lisätä useita luokkia erottamalla ne välilyönneillä: Voit myös välittää funktion, jonka pitäisi palauttaa yksi merkkijono, joka sisältää muita luokkien nimiä. |
rajaa | merkkijono | elementti | 'scrollParent' | Ponnahdusikkunan ylivuotorajoitusraja. Hyväksyy arvot 'viewport' , 'window' , 'scrollParent' , tai HTMLElement-viittauksen (vain JavaScript). Lisätietoja on Popperin preventOverflow -dokumenteissa . |
puhdistaa | boolean | totta | Ota desinfiointi käyttöön tai poista se käytöstä. Jos aktivoitu 'template' , 'content' ja 'title' vaihtoehdot desinfioidaan. Katso desinfiointiosio JavaScript-dokumentaatiossamme . |
valkoinen lista | esine | Oletusarvo | Objekti, joka sisältää sallitut attribuutit ja tunnisteet |
desinfioiFn | nolla | toiminto | tyhjä | Täällä voit toimittaa oman desinfiointitoiminnon. Tästä voi olla hyötyä, jos haluat käyttää desinfiointiin erityistä kirjastoa. |
popperConfig | nolla | esine | tyhjä | Jos haluat muuttaa Bootstrapin Popperin oletusasetuksia, katso Popperin asetukset |
Tietoattribuutit yksittäisille ponnahdusikkunoille
Vaihtoehtoisesti yksittäisten ponnahdusikkunoiden asetukset voidaan määrittää käyttämällä dataattribuutteja, kuten edellä on selitetty.
menetelmät
Asynkroniset menetelmät ja siirtymät
Kaikki API - menetelmät ovat asynkronisia ja aloittavat siirtymän . He palaavat soittajan luo heti siirtymisen alkaessa, mutta ennen sen päättymistä . Lisäksi siirtyvän komponentin menetelmäkutsu jätetään huomioimatta .
$().popover(options)
Alustaa elementtikokoelman ponnahdusikkunat.
.popover('show')
Paljastaa elementin ponnahdusikkunan. Palaa soittajalle ennen kuin ponnahdusikkuna on todella näytetty (eli ennen shown.bs.popover
tapahtumaa). Tätä pidetään ponnahdusikkunan "manuaalisena" laukaisuna. Ponnahdusikkunoita, joiden otsikko ja sisältö ovat nollapituisia, ei koskaan näytetä.
$('#element').popover('show')
.popover('hide')
Piilottaa elementin ponnahdusikkunan. Palaa soittajalle ennen kuin ponnahdusikkuna on todella piilotettu (eli ennen hidden.bs.popover
tapahtumaa). Tätä pidetään ponnahdusikkunan "manuaalisena" laukaisuna.
$('#element').popover('hide')
.popover('toggle')
Vaihtaa elementin ponnahdusikkunan. Palaa soittajalle ennen kuin ponnahdusikkuna on todella näkynyt tai piilotettu (ts. ennen shown.bs.popover
tai hidden.bs.popover
tapahtumaa). Tätä pidetään ponnahdusikkunan "manuaalisena" laukaisuna.
$('#element').popover('toggle')
.popover('dispose')
Piilottaa ja tuhoaa elementin ponnahdusikkunan. Ponnahdusikkunoita, jotka käyttävät delegointia (jotka luodaan vaihtoehdolla ) selector
, ei voida tuhota yksitellen jälkeläisissä triggerelementeissä.
$('#element').popover('dispose')
.popover('enable')
Antaa elementin ponnahdusikkunalle mahdollisuuden näkyä. Ponnahdusikkunat ovat oletuksena käytössä.
$('#element').popover('enable')
.popover('disable')
Poistaa mahdollisuuden näyttää elementin ponnahdusikkuna. Ponnahdusikkuna voidaan näyttää vain, jos se otetaan uudelleen käyttöön.
$('#element').popover('disable')
.popover('toggleEnabled')
Vaihtaa elementin ponnahdusikkunan näyttämisen tai piilotuksen.
$('#element').popover('toggleEnabled')
.popover('update')
Päivittää elementin ponnahdusikkunan sijainnin.
$('#element').popover('update')
Tapahtumat
Tapahtumatyyppi | Kuvaus |
---|---|
show.bs.popover | Tämä tapahtuma käynnistyy välittömästi, kun show instanssimenetelmää kutsutaan. |
näytetään.bs.popover | Tämä tapahtuma käynnistyy, kun ponnahdusikkuna on tehty käyttäjän näkyväksi (odottaa CSS-siirtymien valmistumista). |
hide.bs.popover | Tämä tapahtuma käynnistyy välittömästi, kun hide instanssimenetelmää on kutsuttu. |
piilotettu.bs.popover | Tämä tapahtuma käynnistyy, kun ponnahdusikkuna on piilotettu käyttäjältä (odottaa CSS-siirtymien valmistumista). |
inserted.bs.popover | Tämä tapahtuma käynnistyy show.bs.popover tapahtuman jälkeen, kun ponnahdusmalli on lisätty DOM:iin. |
$('#myPopover').on('hidden.bs.popover', function () {
// do something...
})