Source

Carousel

In slideshow-komponint foar it fytsen troch eleminten - ôfbyldings of dia's fan tekst - lykas in karrousel.

Hoe't it wurket

De karrousel is in diashow foar it fytsen troch in searje ynhâld, boud mei CSS 3D-transformaasjes en in bytsje JavaScript. It wurket mei in searje ôfbyldings, tekst, as oanpaste markup. It omfettet ek stipe foar foarige / folgjende kontrôles en yndikatoaren.

Yn browsers dêr't de Page Visibility API wurdt stipe, sil de karrousel it glydzjen foarkomme as de webside net sichtber is foar de brûker (lykas as de blêderljepper ynaktyf is, it browserfinster wurdt minimalisearre, ensfh.).

It animaasje-effekt fan dizze komponint is ôfhinklik fan 'e prefers-reduced-motionmediafraach. Sjoch de seksje mei fermindere beweging fan ús dokumintaasje foar tagonklikens .

Wês asjebleaft bewust dat nestele karrousels net wurde stipe, en karrousels binne oer it algemien net foldogge oan tagonklikensnoarmen.

As lêste, as jo ús JavaScript fan boarne bouwe, fereasketutil.js it .

Foarbyld

Carousels normalisearje diadimensjes net automatysk. As sadanich moatte jo miskien ekstra nutsbedriuwen of oanpaste stilen brûke om ynhâld op passende grutte te meitsjen. Wylst karrousels foarige / folgjende kontrôles en yndikatoaren stypje, binne se net eksplisyt ferplicht. Foegje en oanpasse as jo goed fine.

De .activeklasse moat tafoege wurde oan ien fan de dia's oars is de karrousel net sichtber. Wês ek wis dat jo in unike id ynstelle op 'e .carouselfoar opsjonele kontrôles, foaral as jo meardere karrousels op ien side brûke. Kontrôle- en yndikatoreleminten moatte in data-targetattribút hawwe (of hreffoar keppelings) dy't oerienkomt mei de id fan it .carouselelemint.

Allinnich slides

Hjir is in karrousel mei allinich dia's. Notysje de oanwêzigens fan 'e .d-blocken .w-100op carouselôfbyldings om blêder standertôfbyldingsôfstimming te foarkommen.

<div id="carouselExampleSlidesOnly" class="carousel slide" data-ride="carousel">
  <div class="carousel-inner">
    <div class="carousel-item active">
        <img src="..." class="d-block w-100" alt="...">
    </div>
    <div class="carousel-item">
      <img src="..." class="d-block w-100" alt="...">
    </div>
    <div class="carousel-item">
      <img src="..." class="d-block w-100" alt="...">
    </div>
  </div>
</div>

Mei kontrôles

De foarige en folgjende kontrôles tafoegje:

<div id="carouselExampleControls" class="carousel slide" data-ride="carousel">
  <div class="carousel-inner">
    <div class="carousel-item active">
      <img src="..." class="d-block w-100" alt="...">
    </div>
    <div class="carousel-item">
      <img src="..." class="d-block w-100" alt="...">
    </div>
    <div class="carousel-item">
      <img src="..." class="d-block w-100" alt="...">
    </div>
  </div>
  <a class="carousel-control-prev" href="#carouselExampleControls" role="button" data-slide="prev">
    <span class="carousel-control-prev-icon" aria-hidden="true"></span>
    <span class="sr-only">Previous</span>
  </a>
  <a class="carousel-control-next" href="#carouselExampleControls" role="button" data-slide="next">
    <span class="carousel-control-next-icon" aria-hidden="true"></span>
    <span class="sr-only">Next</span>
  </a>
</div>

Mei yndikatoaren

Jo kinne ek de yndikatoaren tafoegje oan 'e karrousel, neist de kontrôles, ek.

<div id="carouselExampleIndicators" class="carousel slide" data-ride="carousel">
  <ol class="carousel-indicators">
    <li data-target="#carouselExampleIndicators" data-slide-to="0" class="active"></li>
    <li data-target="#carouselExampleIndicators" data-slide-to="1"></li>
    <li data-target="#carouselExampleIndicators" data-slide-to="2"></li>
  </ol>
  <div class="carousel-inner">
    <div class="carousel-item active">
      <img src="..." class="d-block w-100" alt="...">
    </div>
    <div class="carousel-item">
      <img src="..." class="d-block w-100" alt="...">
    </div>
    <div class="carousel-item">
      <img src="..." class="d-block w-100" alt="...">
    </div>
  </div>
  <a class="carousel-control-prev" href="#carouselExampleIndicators" role="button" data-slide="prev">
    <span class="carousel-control-prev-icon" aria-hidden="true"></span>
    <span class="sr-only">Previous</span>
  </a>
  <a class="carousel-control-next" href="#carouselExampleIndicators" role="button" data-slide="next">
    <span class="carousel-control-next-icon" aria-hidden="true"></span>
    <span class="sr-only">Next</span>
  </a>
</div>

Mei ûnderskriften

Foegje maklik titels ta oan jo dia's mei it .carousel-captionelemint yn elke .carousel-item. Se kinne maklik wurde ferburgen op lytsere viewports, lykas hjirûnder werjûn, mei opsjonele display-hulpprogramma's . Wy ferbergje se yn earste ynstânsje mei .d-noneen bringe se werom op middelgrutte apparaten mei .d-md-block.

<div class="bd-example">
  <div id="carouselExampleCaptions" class="carousel slide" data-ride="carousel">
    <ol class="carousel-indicators">
      <li data-target="#carouselExampleCaptions" data-slide-to="0" class="active"></li>
      <li data-target="#carouselExampleCaptions" data-slide-to="1"></li>
      <li data-target="#carouselExampleCaptions" data-slide-to="2"></li>
    </ol>
    <div class="carousel-inner">
      <div class="carousel-item active">
        <img src="..." class="d-block w-100" alt="...">
        <div class="carousel-caption d-none d-md-block">
          <h5>First slide label</h5>
          <p>Nulla vitae elit libero, a pharetra augue mollis interdum.</p>
        </div>
      </div>
      <div class="carousel-item">
        <img src="..." class="d-block w-100" alt="...">
        <div class="carousel-caption d-none d-md-block">
          <h5>Second slide label</h5>
          <p>Lorem ipsum dolor sit amet, consectetur adipiscing elit.</p>
        </div>
      </div>
      <div class="carousel-item">
        <img src="..." class="d-block w-100" alt="...">
        <div class="carousel-caption d-none d-md-block">
          <h5>Third slide label</h5>
          <p>Praesent commodo cursus magna, vel scelerisque nisl consectetur.</p>
        </div>
      </div>
    </div>
    <a class="carousel-control-prev" href="#carouselExampleCaptions" role="button" data-slide="prev">
      <span class="carousel-control-prev-icon" aria-hidden="true"></span>
      <span class="sr-only">Previous</span>
    </a>
    <a class="carousel-control-next" href="#carouselExampleCaptions" role="button" data-slide="next">
      <span class="carousel-control-next-icon" aria-hidden="true"></span>
      <span class="sr-only">Next</span>
    </a>
  </div>
</div>

Crossfade

Foegje .carousel-fadeoan jo karrousel ta om dia's te animearjen mei in fade-oergong ynstee fan in dia.

<div id="carouselExampleFade" class="carousel slide carousel-fade" data-ride="carousel">
  <div class="carousel-inner">
    <div class="carousel-item active">
      <img src="..." class="d-block w-100" alt="...">
    </div>
    <div class="carousel-item">
      <img src="..." class="d-block w-100" alt="...">
    </div>
    <div class="carousel-item">
      <img src="..." class="d-block w-100" alt="...">
    </div>
  </div>
  <a class="carousel-control-prev" href="#carouselExampleFade" role="button" data-slide="prev">
    <span class="carousel-control-prev-icon" aria-hidden="true"></span>
    <span class="sr-only">Previous</span>
  </a>
  <a class="carousel-control-next" href="#carouselExampleFade" role="button" data-slide="next">
    <span class="carousel-control-next-icon" aria-hidden="true"></span>
    <span class="sr-only">Next</span>
  </a>
</div>

Taheakje data-interval=""oan in .carousel-itemom de tiid te feroarjen om te fertrage tusken automatysk fytsen nei it folgjende item.

<div id="carouselExampleInterval" class="carousel slide" data-ride="carousel">
  <div class="carousel-inner">
    <div class="carousel-item active" data-interval="10000">
      <img src="..." class="d-block w-100" alt="...">
    </div>
    <div class="carousel-item" data-interval="2000">
      <img src="..." class="d-block w-100" alt="...">
    </div>
    <div class="carousel-item">
      <img src="..." class="d-block w-100" alt="...">
    </div>
  </div>
  <a class="carousel-control-prev" href="#carouselExampleInterval" role="button" data-slide="prev">
    <span class="carousel-control-prev-icon" aria-hidden="true"></span>
    <span class="sr-only">Previous</span>
  </a>
  <a class="carousel-control-next" href="#carouselExampleInterval" role="button" data-slide="next">
    <span class="carousel-control-next-icon" aria-hidden="true"></span>
    <span class="sr-only">Next</span>
  </a>
</div>

Gebrûk

Fia data attributen

Brûk gegevensattributen om de posysje fan 'e karrousel maklik te kontrolearjen. data-slideakseptearret de kaaiwurden prevof next, dy't de slideposysje feroaret relatyf oan syn hjoeddeistige posysje. As alternatyf, brûk data-slide-toom in rûge slide-yndeks troch te jaan oan de karrousel data-slide-to="2", dy't de slideposysje ferpleatst nei in bepaalde yndeks dy't begjint mei 0.

It data-ride="carousel"attribút wurdt brûkt om in karrousel te markearjen as animaasje te begjinnen by it laden fan siden. As jo ​​​​net brûke data-ride="carousel"om jo karrousel te inisjalisearjen, moatte jo it sels inisjalisearje. It kin net brûkt wurde yn kombinaasje mei (oerstallige en net nedich) eksplisite JavaSkript inisjalisaasje fan deselde carousel.

Fia JavaScript

Rop karrousel manuell mei:

$('.carousel').carousel()

Opsjes

Opsjes kinne wurde trochjûn fia gegevensattributen of JavaScript. Foar gegevensattributen foegje de opsjenamme ta oan data-, lykas yn data-interval="".

Namme Type Standert Beskriuwing
tuskenskoft nûmer 5000 De hoemannichte tiid om te fertrage tusken it automatysk fytsen fan in item. As falsk, sil carousel net automatysk fytse.
toetseboerd boolean wier Oft de karrousel moat reagearje op toetseboerdeveneminten.
skoft string | boolean "sweve"

As ynsteld op "hover", stopet it fytsen fan 'e karrousel oan mouseenteren ferfetsje it fytsen fan' e karrousel op mouseleave. As ynsteld op false, sil it hoverjen oer de karrousel it net ûnderbrekke.

Op touch-ynskeakele apparaten, as ynsteld op "hover", sil it fytsen ûnderbrekke touchend(ienris de brûker klear is mei ynteraksje mei de karrousel) foar twa yntervallen, foardat it automatysk opnij wurdt. Tink derom dat dit neist it boppesteande mûsgedrach is.

rit string falsk Speelt de karrousel automatysk nei't de brûker it earste item mei de hân fytst. As "carousel", autoplays de carousel op load.
wrap boolean wier Oft de karrousel kontinu fytse moat of hurde stops hawwe.
oanreitsje boolean wier Oft de karrousel links/rjochts swipe-ynteraksjes op touchscreen-apparaten moat stypje.

Metoaden

Asynchrone metoaden en transysjes

Alle API-metoaden binne asynchrone en begjinne in oergong . Se komme werom nei de beller sa gau as de oergong is begon, mar foardat it einiget . Derneist sil in metoadeoprop op in oergongskomponint wurde negearre .

Sjoch ús JavaScript-dokumintaasje foar mear ynformaasje .

.carousel(options)

Inisjalisearret de karrousel mei in opsjonele opsjes objecten begjint te fytsen troch items.

$('.carousel').carousel({
  interval: 2000
})

.carousel('cycle')

Cycles troch de karrousel items fan links nei rjochts.

.carousel('pause')

Stopt de karrousel fan it fytsen troch items.

.carousel(number)

Sylt de karrousel nei in bepaald frame (0 basearre, fergelykber mei in array). Keart werom nei de beller foardat it doelitem is werjûn (dus foardat it slid.bs.carouselevenemint bart).

.carousel('prev')

Cycles nei it foarige item. Keart werom nei de beller foardat it foarige item is toand (dus foardat it slid.bs.carouselbarren plakfynt).

.carousel('next')

Cycles nei it folgjende item. Keart werom nei de beller foardat it folgjende item is toand (dus foardat it slid.bs.carouselbarren plakfynt).

.carousel('dispose')

Ferneatiget de karrousel fan in elemint.

Eveneminten

De karrouselklasse fan Bootstrap bleatstelt twa eveneminten foar heakjen oan karrouselfunksjonaliteit. Beide eveneminten hawwe de folgjende ekstra eigenskippen:

  • direction: De rjochting wêryn't de karrousel glydt (of "left"of "right").
  • relatedTarget: It DOM-elemint dat op syn plak wurdt glide as it aktive item.
  • from: De yndeks fan it aktuele item
  • to: De yndeks fan it folgjende item

Alle karrouseleveneminten wurde op de karrousel sels ûntslein (dus by de <div class="carousel">).

Event Type Beskriuwing
slide.bs.carousel Dit evenemint ûntspringt fuortendaliks as de slideeksimplaarmetoade wurdt oproppen.
slid.bs.carrousel Dit evenemint wurdt ûntslein as de karrousel syn slide-oergong foltôge hat.
$('#myCarousel').on('slide.bs.carousel', function () {
  // do something...
})

Feroarje oergong doer

De oergongsdoer fan .carousel-itemkin feroare wurde mei de $carousel-transitionSass-fariabele foardat jo kompilearje of oanpaste stilen as jo de kompilearre CSS brûke. As meardere transysjes wurde tapast, soargje derfoar dat de transformaasje-oergong earst definiearre is (bgl. transition: transform 2s ease, opacity .5s ease-out).