Karuselli
Diaesityskomponentti, jolla voi kiertää elementtejä – kuvia tai tekstidioja – kuten karuselli.
Kuinka se toimii
Karuselli on diaesitys sisältösarjan läpi pyöräilemiseen, ja se on rakennettu CSS 3D -muunnoksilla ja hieman JavaScriptillä. Se toimii kuvasarjan, tekstin tai mukautetun merkinnän kanssa. Se sisältää myös tuen edellisille/seuraaville säätimille ja ilmaisimille.
Selaimissa, joissa sivun näkyvyyden sovellusliittymää tuetaan, karuselli välttää liukumista, kun verkkosivu ei ole käyttäjälle näkyvissä (kuten kun selaimen välilehti ei ole aktiivinen, selainikkuna on pienennetty jne.).
Tämän komponentin animaatiovaikutus riippuu prefers-reduced-motion
mediakyselystä. Katso esteettömyysdokumentaation osio liikkeen vähentämisestä .
Huomaa, että sisäkkäisiä karuselleja ei tueta, eivätkä karusellit yleensä ole esteettömyysstandardien mukaisia.
Lopuksi, jos rakennat JavaScript-koodiamme lähteestä, se vaatiiutil.js
.
Esimerkki
Karusellit eivät normalisoi diojen mittoja automaattisesti. Sellaisenaan saatat joutua käyttämään lisäapuohjelmia tai mukautettuja tyylejä sisällön sopivan koon mitoittamiseksi. Vaikka karusellit tukevat edellisiä/seuraavia säätimiä ja ilmaisimia, niitä ei erikseen vaadita. Lisää ja muokkaa haluamallasi tavalla.
Luokka on .active
lisättävä johonkin dioista, muuten karuselli ei näy. Muista myös asettaa yksilöllinen tunnus .carousel
valinnaisille säätimille, varsinkin jos käytät useita karuselleja yhdellä sivulla. Ohjaus- ja indikaattorielementeillä on oltava data-target
attribuutti (tai href
linkeissä), joka vastaa .carousel
elementin tunnusta.
Vain dioja
Tässä on karuselli, jossa on vain dioja. .d-block
Huomaa karusellikuvien ja -merkkien läsnäolo .w-100
estääksesi selaimen oletuskuvan kohdistuksen.
Ohjainten kanssa
Edellisen ja seuraavan säätimen lisääminen:
Indikaattorien kanssa
Voit myös lisätä ilmaisimia karuselliin ohjaimien rinnalle.
Tekstityksillä
Lisää kuvatekstejä dioihisi helposti minkä .carousel-caption
tahansa elementin avulla .carousel-item
. Ne voidaan helposti piilottaa pienempiin kuvaportteihin, kuten alla on esitetty, valinnaisten näyttöapuohjelmien avulla . Piilotamme ne aluksi sovelluksella .d-none
ja tuomme ne takaisin keskikokoisille laitteille -sovelluksella .d-md-block
.
Crossfade
Lisää .carousel-fade
karuselliisi animoidaksesi dioja häivytyksellä dian sijaan.
Yksilöllinen .carousel-item
intervalli
Lisää data-interval=""
kohtaan a .carousel-item
muuttaaksesi ajan, joka kuluu automaattisesti seuraavaan kohteeseen siirtymisen välillä.
Käyttö
Tietomääritteiden kautta
Käytä tietoattribuutteja karusellin sijainnin hallintaan. data-slide
hyväksyy avainsanat prev
tai next
, joka muuttaa dian sijaintia suhteessa sen nykyiseen sijaintiin. Vaihtoehtoisesti data-slide-to
voit siirtää raakadiaindeksin karuselliin data-slide-to="2"
, joka siirtää dian sijainnin tiettyyn hakemistoon, joka alkaa merkillä 0
.
Attribuuttia data-ride="carousel"
käytetään merkitsemään karuselli animaatioksi sivun latauksesta alkaen. Jos et käytä data-ride="carousel"
karusellin alustamiseen, sinun on alustettava se itse. Sitä ei voi käyttää yhdessä (redundantin ja tarpeettoman) eksplisiittisen JavaScript-alustuksen kanssa samassa karusellissa.
JavaScriptin kautta
Soita karuselliin manuaalisesti:
Vaihtoehdot
Vaihtoehdot voidaan välittää tietomääritteiden tai JavaScriptin kautta. Liitä tietomääritteissä vaihtoehdon nimi kohtaan data-
, kuten kohdassa data-interval=""
.
Nimi | Tyyppi | Oletus | Kuvaus |
---|---|---|---|
intervalli | määrä | 5000 | Aika, joka kestää kohteen automaattisen kierron välillä. Jos se on epätosi, karuselli ei pyöri automaattisesti. |
näppäimistö | boolean | totta | Pitääkö karusellin reagoida näppäimistötapahtumiin. |
tauko | merkkijono | boolean | "hover" | Jos asetus on Kosketuskäyttöisissä laitteissa, kun asetus on |
ratsastaa | merkkijono | väärä | Toistaa karusellin automaattisesti, kun käyttäjä on kierrättänyt ensimmäisen kohteen manuaalisesti. Jos "karuselli", toistaa karusellin automaattisesti latauksen aikana. |
kääri | boolean | totta | Pitäisikö karusellin pyöräillä jatkuvasti vai pysähdyksissä. |
kosketus | boolean | totta | Tukeeko karuselli vasemmalle/oikealle pyyhkäisyä kosketusnäytöllisissä laitteissa. |
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 .
.carousel(options)
Alustaa karusellin valinnaisilla vaihtoehdoilla object
ja alkaa selata kohteita.
.carousel('cycle')
Kiertelee karusellikohteita vasemmalta oikealle.
.carousel('pause')
Estää karusellia pyöräilemästä esineiden läpi.
.carousel(number)
Kierrättää karusellin tiettyyn kehykseen (0-pohjainen, samanlainen kuin taulukko). Palaa soittajalle ennen kuin kohdekohde on näytetty (eli ennen slid.bs.carousel
tapahtumaa).
.carousel('prev')
Siirtyy edelliseen kohtaan. Palaa soittajalle ennen kuin edellinen kohde on näytetty (eli ennen slid.bs.carousel
tapahtumaa).
.carousel('next')
Siirtyy seuraavaan kohteeseen. Palaa soittajalle ennen kuin seuraava kohde on näytetty (eli ennen slid.bs.carousel
tapahtumaa).
.carousel('dispose')
Tuhoaa elementin karusellin.
Tapahtumat
Bootstrapin karuselliluokka paljastaa kaksi tapahtumaa, jotka liittyvät karusellitoimintoihin. Molemmilla tapahtumilla on seuraavat lisäominaisuudet:
direction
: Suunta, johon karuselli liukuu (joko"left"
tai"right"
).relatedTarget
: DOM-elementti, joka liu'utetaan paikalleen aktiivisena kohteena.from
: Nykyisen kohteen hakemistoto
: Seuraavan kohteen hakemisto
Kaikki karusellitapahtumat laukaistaan itse karuselliin (eli kohtaan <div class="carousel">
).
Tapahtumatyyppi | Kuvaus |
---|---|
slide.bs.carousel | Tämä tapahtuma käynnistyy välittömästi, kun slide instanssimenetelmää kutsutaan. |
slid.bs.karuselli | Tämä tapahtuma käynnistyy, kun karuselli on suorittanut diasiirtymän. |
Muuta siirtymän kestoa
Siirron kestoa .carousel-item
voidaan muuttaa $carousel-transition
Sass-muuttujalla ennen kääntämistä tai mukautetuilla tyyleillä, jos käytät käännettyä CSS:ää. Jos käytetään useita siirtymiä, varmista, että muunnossiirtymä on määritetty ensin (esim. transition: transform 2s ease, opacity .5s ease-out
).