Bootstrap-Karussell mehrere Frames gleichzeitig

110

Dies ist der Effekt, den ich mit dem Bootstrap 3-Karussell erzielen möchte

Geben Sie hier die Bildbeschreibung ein

Anstatt jeweils nur einen Frame anzuzeigen, werden N Frames nebeneinander angezeigt. Wenn Sie dann schieben (oder wenn es automatisch gleitet), verschiebt es die Gruppe von Folien wie es ist.

Kann dies mit dem Karussell von Bootstrap 3 durchgeführt werden? Ich hoffe, ich muss nicht nach einem weiteren jQuery-Plugin suchen ...

Rodrigo-Silveira
quelle
Entschuldigung, bereits angepasstes Bootstrap 4, aber einfach zu ändern stackoverflow.com/a/42098033/4796923
Oleg V Karun
Es gibt eine neue Lösung für dieses Problem mit Ken Wheelers Slick Carousel, die einfacher zu implementieren und eleganter als diese ist. Bitte sehen Sie die Antwort von @joshmoto mit dem vollständigen Code hier> stackoverflow.com/a/54263516/345605
ganar

Antworten:

20

Kann dies mit dem Karussell von Bootstrap 3 durchgeführt werden? Ich hoffe, ich muss nicht nach einem weiteren jQuery-Plugin suchen

Ab dem 08.12.2013 lautet die Antwort nein. Der gesuchte Effekt ist mit dem generischen Karussell-Plugin von Bootstrap 3 nicht möglich. Hier ist jedoch ein einfaches jQuery-Plugin, das genau das zu tun scheint, was Sie wollen. Http://sorgalla.com/jcarousel/

Ronald
quelle
147

Aktualisiert 2019 ...

Bootstrap 4

Das Karussell wurde in 4.x geändert, und die Animationsübergänge mit mehreren Folien können wie folgt überschrieben werden ...

.carousel-inner .carousel-item-right.active,
.carousel-inner .carousel-item-next {
  transform: translateX(33.33%);
}

.carousel-inner .carousel-item-left.active, 
.carousel-inner .carousel-item-prev {
  transform: translateX(-33.33%)
}

.carousel-inner .carousel-item-right,
.carousel-inner .carousel-item-left{ 
  transform: translateX(0);
}

Bootstrap 4 Alpha.6 Demo
Bootstrap 4.0.0 ( 4 anzeigen , jeweils 1 vorrücken)
Bootstrap 4.1.0 (3 anzeigen , jeweils 1 vorrücken)
Bootstrap 4.1.0 (alle 4 gleichzeitig vorrücken)
Bootstrap 4.3.1 reagiert (mehrere newanzeigen , vorrücken 1)
Bootstrap 4.3.1-Karussell mit Kartennew


Eine weitere Option ist ein ansprechendes Karussell, das nur 1 Folie auf kleineren Bildschirmen anzeigt und vorschiebt , aber zeigt, dass mehrere Folien größere Bildschirme sind . Anstatt die Folien wie im vorherigen Beispiel zu klonen, wird das CSS angepasst und mit jQuery nur die zusätzlichen Folien verschoben, um ein kontinuierliches Radfahren (Wrap Around) zu ermöglichen:

Bitte kopieren Sie diesen Code nicht einfach und fügen Sie ihn ein. Verstehe zuerst, wie es funktioniert.

Bootstrap 4 Responsive (3, 1 Folie auf dem Handy anzeigen)

@media (min-width: 768px) {

    /* show 3 items */
    .carousel-inner .active,
    .carousel-inner .active + .carousel-item,
    .carousel-inner .active + .carousel-item + .carousel-item {
        display: block;
    }

    .carousel-inner .carousel-item.active:not(.carousel-item-right):not(.carousel-item-left),
    .carousel-inner .carousel-item.active:not(.carousel-item-right):not(.carousel-item-left) + .carousel-item,
    .carousel-inner .carousel-item.active:not(.carousel-item-right):not(.carousel-item-left) + .carousel-item + .carousel-item {
        transition: none;
    }

    .carousel-inner .carousel-item-next,
    .carousel-inner .carousel-item-prev {
      position: relative;
      transform: translate3d(0, 0, 0);
    }

    .carousel-inner .active.carousel-item + .carousel-item + .carousel-item + .carousel-item {
        position: absolute;
        top: 0;
        right: -33.3333%;
        z-index: -1;
        display: block;
        visibility: visible;
    }

    /* left or forward direction */
    .active.carousel-item-left + .carousel-item-next.carousel-item-left,
    .carousel-item-next.carousel-item-left + .carousel-item,
    .carousel-item-next.carousel-item-left + .carousel-item + .carousel-item,
    .carousel-item-next.carousel-item-left + .carousel-item + .carousel-item + .carousel-item {
        position: relative;
        transform: translate3d(-100%, 0, 0);
        visibility: visible;
    }

    /* farthest right hidden item must be abso position for animations */
    .carousel-inner .carousel-item-prev.carousel-item-right {
        position: absolute;
        top: 0;
        left: 0;
        z-index: -1;
        display: block;
        visibility: visible;
    }

    /* right or prev direction */
    .active.carousel-item-right + .carousel-item-prev.carousel-item-right,
    .carousel-item-prev.carousel-item-right + .carousel-item,
    .carousel-item-prev.carousel-item-right + .carousel-item + .carousel-item,
    .carousel-item-prev.carousel-item-right + .carousel-item + .carousel-item + .carousel-item {
        position: relative;
        transform: translate3d(100%, 0, 0);
        visibility: visible;
        display: block;
        visibility: visible;
    }

}

<div class="container-fluid">
    <div id="carouselExample" class="carousel slide" data-ride="carousel" data-interval="9000">
        <div class="carousel-inner row w-100 mx-auto" role="listbox">
            <div class="carousel-item col-md-4 active">
                <img class="img-fluid mx-auto d-block" src="//placehold.it/600x400/000/fff?text=1" alt="slide 1">
            </div>
            <div class="carousel-item col-md-4">
                <img class="img-fluid mx-auto d-block" src="//placehold.it/600x400?text=2" alt="slide 2">
            </div>
            <div class="carousel-item col-md-4">
                <img class="img-fluid mx-auto d-block" src="//placehold.it/600x400?text=3" alt="slide 3">
            </div>
            <div class="carousel-item col-md-4">
                <img class="img-fluid mx-auto d-block" src="//placehold.it/600x400?text=4" alt="slide 4">
            </div>
            <div class="carousel-item col-md-4">
                <img class="img-fluid mx-auto d-block" src="//placehold.it/600x400?text=5" alt="slide 5">
            </div>
            <div class="carousel-item col-md-4">
                <img class="img-fluid mx-auto d-block" src="//placehold.it/600x400?text=6" alt="slide 6">
            </div>
            <div class="carousel-item col-md-4">
                <img class="img-fluid mx-auto d-block" src="//placehold.it/600x400?text=7" alt="slide 7">
            </div>
            <div class="carousel-item col-md-4">
                <img class="img-fluid mx-auto d-block" src="//placehold.it/600x400?text=8" alt="slide 7">
            </div>
        </div>
        <a class="carousel-control-prev" href="#carouselExample" role="button" data-slide="prev">
            <i class="fa fa-chevron-left fa-lg text-muted"></i>
            <span class="sr-only">Previous</span>
        </a>
        <a class="carousel-control-next text-faded" href="#carouselExample" role="button" data-slide="next">
            <i class="fa fa-chevron-right fa-lg text-muted"></i>
            <span class="sr-only">Next</span>
        </a>
    </div>
</div>

Beispiel - Bootstrap 4 Responsive (4, 1 Folie auf dem Handy anzeigen )
Beispiel - Bootstrap 4 Responsive (5, 1 Folie auf dem Handy anzeigen)


Bootstrap 3

Hier ist ein 3.x-Beispiel für Bootply: http://bootply.com/89193

Sie müssen eine ganze Reihe von Bildern in das aktive Element einfügen. Hier ist eine andere Version, die die Bilder nicht bei kleineren Bildschirmbreiten stapelt: http://bootply.com/92514

BEARBEITEN Alternativer Ansatz, um jeweils eine Folie voranzutreiben :

Verwenden Sie jQuery, um die nächsten Elemente zu klonen.

$('.carousel .item').each(function(){
  var next = $(this).next();
  if (!next.length) {
    next = $(this).siblings(':first');
  }
  next.children(':first-child').clone().appendTo($(this));

  if (next.next().length>0) {
    next.next().children(':first-child').clone().appendTo($(this));
  }
  else {
    $(this).siblings(':first').children(':first-child').clone().appendTo($(this));
  }
});

Und dann CSS entsprechend positionieren ...

Vor 3.3.1

.carousel-inner .active.left { left: -33%; }
.carousel-inner .next        { left:  33%; }

Nach 3.3.1

.carousel-inner .item.left.active {
  transform: translateX(-33%);
}
.carousel-inner .item.right.active {
  transform: translateX(33%);
}

.carousel-inner .item.next {
  transform: translateX(33%)
}
.carousel-inner .item.prev {
  transform: translateX(-33%)
}

.carousel-inner .item.right,
.carousel-inner .item.left { 
  transform: translateX(0);
}

Dies zeigt 3 gleichzeitig an, aber es wird jeweils nur eine Folie angezeigt:

Bootstrap 3.x Demo


Bitte kopieren Sie diesen Code nicht und fügen Sie ihn nicht ein. Verstehe zuerst, wie es funktioniert. Diese Antwort soll Ihnen beim Lernen helfen .

Das Verdoppeln dieses modifizierten Bootstrap 4-Karussells funktioniert nur zur Hälfte korrekt (die Bildlaufschleife funktioniert nicht mehr).
Wie werden 2 Bootstrap-Schieberegler auf einer Seite erstellt, ohne dass CSS und JQuery gemischt werden?
Bootstrap 4 Multi Carousel zeigt 4 statt 3 Bilder

Zim
quelle
6
Vielen Dank. Das sieht viel besser aus ... fühlt sich aber etwas komisch an. Das Scrollen nach links scheint nicht zu funktionieren, da mehrere Blöcke gleichzeitig gescrollt werden und die Reihenfolge nicht stimmt. Das Scrollen nach rechts funktioniert einwandfrei (allerdings in die falsche Richtung). Das Problem, das ich damit habe, ist, dass es viele Duplikate zu erstellen scheint, was nicht so schlimm ist ... aber nicht so gut ... also erstellt dieses Skript für jedes Element, das ich habe (6 in Ihrem Fall) N Duplikate (wobei N = Blöcke pro Frame angezeigt werden).
Rodrigo-Silveira
5
@Zentaurus, ich weiß, dass es spät ist, aber sehen Sie sich das Beispiel mit vier Elementen an . Ich habe die Skelly-Logik für eine SOpt-Frage angepasst .
Anthony Accioly
3
Finden Sie heraus, warum es bei> 3.3.0 nicht funktioniert. Es liegt an der Aufnahme von translate3D. Überprüfen Sie die Antworten von Danijel und Michal Vrchota unter: stackoverflow.com/questions/18613271/…
Jorge Sampayo
2
@Zim diese Demo hält 1 Folie sichtbar. Ich hoffe, 3 oder 4 (so viele wie der Bildschirm passt) anzuzeigen und danach 1 Element anzuzeigen.
Junior
1
@Junior Genau, in der neuesten Version (4.3.1) war das einzige, was es für mich zum Laufen gebracht hat, die Margin-Anpassung, die in einer anderen Antwort hier erklärt wurde .
Armfoot
30

Alle oben genannten Lösungen sind hacky und fehlerhaft. Versuche es nicht einmal. Verwenden Sie andere Bibliotheken. Das Beste, was ich gefunden habe - http://sachinchoolur.github.io/lightslider Funktioniert hervorragend mit Bootstrap, fügt kein Junk-HTML hinzu, ist hoch konfigurierbar, reaktionsschnell, mobilfreundlich usw.

$('.multi-item-carousel').lightSlider({
    item: 4,
    pager: false,
    autoWidth: false,
    slideMargin: 0
});
ymakux
quelle
Vielen Dank, sehr nützlich lib :)
GuiPab
Einige dieser Slider-Bibliotheken stellen tatsächlich das in den Schatten, was Bootstrap, sogar 4, bietet. Danke für das Teilen.
KhoPhi
Der Schieberegler dupliziert Folien. Siehe Beispiel-Slider-Soruce-Code auf ihrer Website.
Marinski
Dies ist ein totes Projekt mit zu vielen offenen Fragen. (Überprüfen Sie ihren Github)
Osama Rashid
20

Dies ist ein funktionierender Twitter-Bootstrap 3.

Hier ist das Javascript :

$('#myCarousel').carousel({
    interval: 10000
})

$('.carousel .item').each(function(){
    var next = $(this).next();

    if (!next.length) {
        next = $(this).siblings(':first');
    }

    next.children(':first-child').clone().appendTo($(this));

    if (next.next().length>0) {
        next.next().children(':first-child').clone().appendTo($(this));
    }
    else {
        $(this).siblings(':first').children(':first-child').clone().appendTo($(this));
    }
});

Und die CSS :

.carousel-inner .active.left  { left: -33%;             }
.carousel-inner .active.right { left: 33%;              }
.carousel-inner .next         { left: 33%               }
.carousel-inner .prev         { left: -33%              }
.carousel-control.left        { background-image: none; }
.carousel-control.right       { background-image: none; }
.carousel-inner .item         { background: white;      }

Sie können es in Aktion auf dieser Jsfiddle sehen

Der Grund, warum ich diese Antwort hinzugefügt habe, weil die anderen nicht ganz funktionieren. Ich habe 2 Fehler in ihnen gefunden, einer davon war, dass der linke Pfeil einen seltsamen Effekt erzeugte und der andere war, dass der Text in einigen Situationen fett wurde, was durch Einstellen der Hintergrundfarbe behoben werden kann, sodass das untere Element während des Übergangs nicht sichtbar ist bewirken.

paulalexandru
quelle
Vielen Dank für das Teilen ... Ich sehe jedoch ein Flackern in Firefox.
Elon Zito
@paulalexandru Wie kann ich die Anzahl der Bilder in der sichtbaren Zeile erhöhen?
Jack Wolier
Nun, falls Sie 4 Elemente in Ihrem CSS haben, sollten Sie 33% mit 25% ändern und Sie müssen auch eine kleine Änderung im Javascript vornehmen. Falls Sie das nicht lösen können, stellen Sie eine Frage und ich werde dort eine vollständige Antwort veröffentlichen.
Paulalexandru
Dies ist eine großartige Lösung! Vielen Dank!
Raiderrobert
1
Ich danke dir sehr. Das hat mir sehr geholfen. Ich erstelle ein benutzerdefiniertes Bootstrap-Thema für eine Drupal 8-Site, das auf dem Barrio-Thema basiert. Es gibt nicht allzu viele Optionen, um ein Karussell anzupassen. Das von Ihnen bereitgestellte JS und CSS funktionierte wie von Zauberhand. Ich musste den Code ein wenig an meine Anforderungen anpassen, aber alles in allem hat es fantastisch funktioniert. Vielen Dank @paulalexandru
sylvery
6

Das hat bei mir funktioniert. Sehr einfaches jQuery und CSS, um reaktionsschnelle Karussells unabhängig von Karussells auf derselben Seite zu erstellen. Sehr anpassbar, aber im Grunde genommen ein Div mit Leerraum-Nowrap, der eine Reihe von Inline-Block-Elementen enthält, und das letzte am Anfang, um sich zurück zu bewegen, oder das erste an das Ende, um sich vorwärts zu bewegen. Danke insertAfter!

$('.carosel-control-right').click(function() {
  $(this).blur();
  $(this).parent().find('.carosel-item').first().insertAfter($(this).parent().find('.carosel-item').last());
});
$('.carosel-control-left').click(function() {
  $(this).blur();
  $(this).parent().find('.carosel-item').last().insertBefore($(this).parent().find('.carosel-item').first());
});
@media (max-width: 300px) {
  .carosel-item {
    width: 100%;
  }
}
@media (min-width: 300px) {
  .carosel-item {
    width: 50%;
  }
}
@media (min-width: 500px) {
  .carosel-item {
    width: 33.333%;
  }
}
@media (min-width: 768px) {
  .carosel-item {
    width: 25%;
  }
}
.carosel {
  position: relative;
  background-color: #000;
}
.carosel-inner {
  white-space: nowrap;
  overflow: hidden;
  font-size: 0;
}
.carosel-item {
  display: inline-block;
}
.carosel-control {
  position: absolute;
  top: 50%;
  padding: 15px;
  box-shadow: 0 0 10px 0px rgba(0, 0, 0, 0.5);
  transform: translateY(-50%);
  border-radius: 50%;
  color: rgba(0, 0, 0, 0.5);
  font-size: 30px;
  display: inline-block;
}
.carosel-control-left {
  left: 15px;
}
.carosel-control-right {
  right: 15px;
}
.carosel-control:active,
.carosel-control:hover {
  text-decoration: none;
  color: rgba(0, 0, 0, 0.8);
}
<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script>
<div class="carosel" id="carosel1">
  <a class="carosel-control carosel-control-left glyphicon glyphicon-chevron-left" href="#"></a>
  <div class="carosel-inner">
    <img class="carosel-item" src="http://placehold.it/500/bbbbbb/fff&amp;text=1" />
    <img class="carosel-item" src="http://placehold.it/500/CCCCCC&amp;text=2" />
    <img class="carosel-item" src="http://placehold.it/500/eeeeee&amp;text=3" />
    <img class="carosel-item" src="http://placehold.it/500/f4f4f4&amp;text=4" />
    <img class="carosel-item" src="http://placehold.it/500/fcfcfc/333&amp;text=5" />
    <img class="carosel-item" src="http://placehold.it/500/f477f4/fff&amp;text=6" />
  </div>
  <a class="carosel-control carosel-control-right glyphicon glyphicon-chevron-right" href="#"></a>
</div>
<div class="carosel" id="carosel2">
  <a class="carosel-control carosel-control-left glyphicon glyphicon-chevron-left" href="#"></a>
  <div class="carosel-inner">
    <img class="carosel-item" src="http://placehold.it/500/bbbbbb/fff&amp;text=1" />
    <img class="carosel-item" src="http://placehold.it/500/CCCCCC&amp;text=2" />
    <img class="carosel-item" src="http://placehold.it/500/eeeeee&amp;text=3" />
    <img class="carosel-item" src="http://placehold.it/500/f4f4f4&amp;text=4" />
    <img class="carosel-item" src="http://placehold.it/500/fcfcfc/333&amp;text=5" />
    <img class="carosel-item" src="http://placehold.it/500/f477f4/fff&amp;text=6" />
  </div>
  <a class="carosel-control carosel-control-right glyphicon glyphicon-chevron-right" href="#"></a>
</div>

Mogsdad
quelle
Danke, kleiner Riese, kannst du mir bitte bei deiner Antwort mit 'Karussell-Indikatoren' helfen? und Auto Slide Feature aktivieren / deaktivieren.
MahiMan
5

Update 2019-03-06 - Bootstrap v4.3.1

Es scheint, dass die neue Bootstrap-Version margin-right: -100%jedem Element ein a hinzufügt. In der Antwortlösung, die in der am besten bewerteten Antwort hier angegeben ist , sollte diese Eigenschaft zurückgesetzt werden, z.

.carousel-inner .carousel-item {
    margin-right: inherit;
}

Ein funktionierender Codepen mit v4.3.1 in LESS .

CPHPython
quelle
Gott segne dich ahaha
Alberto Bellini
1
Für alle, die mit der oben am besten ausgewählten Antwort zu kämpfen haben, funktioniert diese Antwort, insbesondere der Codepen-Link, hervorragend mit Bootstrap v4.4.0. Mit ein wenig Optimierung können Sie es problemlos mit 4 sichtbaren Folien oder was auch immer Sie brauchen zum Laufen bringen. Danke fürs Schreiben.
Crdunst
3

Die beliebteste Antwort ist richtig, aber ich denke, der Code ist nutzlos kompliziert. Mit dem gleichen CSS ist dieser Abfragecode meiner Meinung nach leichter zu verstehen:

$('#myCarousel').carousel({
  interval: 10000
})

$('.carousel .item').each(function() {
  var item = $(this);
  item.siblings().each(function(index) {
    if (index < 4) {
      $(this).children(':first-child').clone().appendTo(item);
    }
  });
});
Luke Skywalker
quelle
Dies funktioniert für mich, obwohl ich feststelle, dass die verschiedenen Elemente eher vertikal als horizontal angeordnet sind, während die Animation noch horizontal ausgeführt wird
Don Giulio
2

versuchen Sie dies ..... es funktioniert in meinem .... Code:

<div class="container">
    <br>
    <div id="myCarousel" class="carousel slide" data-ride="carousel">
        <!-- Indicators -->
        <ol class="carousel-indicators">
            <li data-target="#myCarousel" data-slide-to="0" class="active"></li>
            <li data-target="#myCarousel" data-slide-to="1"></li>
            <li data-target="#myCarousel" data-slide-to="2"></li>
            <li data-target="#myCarousel" data-slide-to="3"></li>
        </ol>

        <!-- Wrapper for slides -->
        <div class="carousel-inner" role="listbox">
            <div class="item active">
                <div class="span4" style="padding-left: 18px;">
                    <img src="http://placehold.it/290x180" class="img-thumbnail">
                    <img src="http://placehold.it/290x180" class="img-thumbnail">
                    <img src="http://placehold.it/290x180" class="img-thumbnail">
                </div>
            </div>
            <div class="item">
                 <div class="span4" style="padding-left: 18px;">
                    <img src="http://placehold.it/290x180" class="img-thumbnail">
                    <img src="http://placehold.it/290x180" class="img-thumbnail">
                    <img src="http://placehold.it/290x180" class="img-thumbnail">
                </div>
            </div>
        </div>
        <a class="right carousel-control" href="#myCarousel" role="button" data-slide="next">
            <span class="glyphicon glyphicon-chevron-right" aria-hidden="true"></span>
            <span class="sr-only">Next</span>
        </a>
    </div>
</div>
Prashant Shastri
quelle
2

    $('#carousel-example-generic').on('slid.bs.carousel', function () {
        $(".item.active:nth-child(" + ($(".carousel-inner .item").length -1) + ") + .item").insertBefore($(".item:first-child"));
        $(".item.active:last-child").insertBefore($(".item:first-child"));
    });    
        .item.active,
        .item.active + .item,
        .item.active + .item  + .item {
           width: 33.3%;
           display: block;
           float:left;
        }          
   <link rel="stylesheet" href="https://maxcdn.bootstrapcdn.com/bootstrap/3.3.6/css/bootstrap.min.css" integrity="sha384-1q8mTJOASx8j1Au+a5WDVnPi2lkFfwwEAa8hDDdjZlpLegxhjVME1fgjWPGmkzs7" crossorigin="anonymous">

<div id="carousel-example-generic" class="carousel slide" data-ride="carousel" style="max-width:800px;">
  <!-- Indicators -->
  <ol class="carousel-indicators">
    <li data-target="#carousel-example-generic" data-slide-to="0" class="active"></li>
    <li data-target="#carousel-example-generic" data-slide-to="1"></li>
    <li data-target="#carousel-example-generic" data-slide-to="2"></li>
  </ol>

  <!-- Wrapper for slides -->
  <div class="carousel-inner" role="listbox">
    <div class="item active">
        <img data-src="holder.js/300x200?text=1">
    </div>
    <div class="item">
        <img data-src="holder.js/300x200?text=2">
    </div>
    <div class="item">
        <img data-src="holder.js/300x200?text=3">
    </div>
    <div class="item">
        <img data-src="holder.js/300x200?text=4">
    </div>
    <div class="item">
        <img data-src="holder.js/300x200?text=5">
    </div>
    <div class="item">
        <img data-src="holder.js/300x200?text=6">
    </div>
    <div class="item">
        <img data-src="holder.js/300x200?text=7">
    </div>    
  </div>

  <!-- Controls -->
  <a class="left carousel-control" href="#carousel-example-generic" role="button" data-slide="prev">
    <span class="glyphicon glyphicon-chevron-left" aria-hidden="true"></span>
    <span class="sr-only">Previous</span>
  </a>
  <a class="right carousel-control" href="#carousel-example-generic" role="button" data-slide="next">
    <span class="glyphicon glyphicon-chevron-right" aria-hidden="true"></span>
    <span class="sr-only">Next</span>
  </a>
</div>
<script src="https://ajax.googleapis.com/ajax/libs/jquery/1.11.3/jquery.min.js"></script>
    <script src="https://maxcdn.bootstrapcdn.com/bootstrap/3.3.6/js/bootstrap.min.js" integrity="sha384-0mSbJDEHialfmuBBQP6A4Qrprq5OVfW37PRR3j5ELqxss1yVqOtnepnHVP9aJ7xS" crossorigin="anonymous"></script>
    <script src="https://cdnjs.cloudflare.com/ajax/libs/holder/2.9.1/holder.min.js"></script>
    

Bass Jobsen
quelle
0

Ich hatte das gleiche Problem und die hier beschriebenen Lösungen funktionierten gut. Ich wollte jedoch Änderungen der Fenstergröße (und des Layouts) unterstützen. Das Ergebnis ist eine kleine Bibliothek, die die gesamte Berechnung löst. Überprüfen Sie es hier: https://github.com/SocialbitGmbH/BootstrapCarouselPageMerger

Damit das Skript funktioniert, müssen Sie einen neuen <div>Wrapper mit der Klasse .item-content direkt in Ihre hinzufügen .item <div>. Beispiel:

<div class="carousel slide multiple" id="very-cool-carousel" data-ride="carousel">
    <div class="carousel-inner" role="listbox">
        <div class="item active">
            <div class="item-content">
                First page
            </div>
        </div>
        <div class="item active">
            <div class="item-content">
                Second page
            </div>
        </div>
    </div>
</div>

Nutzung dieser Bibliothek:

socialbitBootstrapCarouselPageMerger.run('div.carousel');

So ändern Sie die Einstellungen:

socialbitBootstrapCarouselPageMerger.settings.spaceCalculationFactor = 0.82;

Beispiel:

Wie Sie sehen können, wird das Karussell aktualisiert, um mehr Steuerelemente anzuzeigen, wenn Sie die Fenstergröße ändern. Überprüfen Sie die watchWindowSizeTimeoutEinstellung, um das Zeitlimit für die Reaktion auf Änderungen der Fenstergröße zu steuern.

Thomas Kekeisen
quelle
0
Try this code


 <div id="recommended-item-carousel" class="carousel slide" data-ride="carousel">
    <div class="carousel-inner">
        <div class="item active">

            <div class="col-sm-3">
                <div class="product-image-wrapper">
                    <div class="single-products">
                        <div class="productinfo text-center">
                            <img src="img/home/recommend1.jpg" alt="" />
                            <h2>$56</h2>
                            <p>
                                Easy Polo Black Edition
                            </p>
                            <a href="#" class="btn btn-default add-to-cart"><i class="fa fa-shopping-cart"></i>Add to cart</a>
                        </div>

                    </div>
                </div>
            </div>
            <div class="col-sm-3">
                <div class="product-image-wrapper">
                    <div class="single-products">
                        <div class="productinfo text-center">
                            <img src="img/home/recommend2.jpg" alt="" />
                            <h2>$56</h2>
                            <p>
                                Easy Polo Black Edition
                            </p>
                            <a href="#" class="btn btn-default add-to-cart"><i class="fa fa-shopping-cart"></i>Add to cart</a>
                        </div>

                    </div>
                </div>
            </div>
            <div class="col-sm-3">
                <div class="product-image-wrapper">
                    <div class="single-products">
                        <div class="productinfo text-center">
                            <img src="img/home/recommend3.jpg" alt="" />
                            <h2>$56</h2>
                            <p>
                                Easy Polo Black Edition
                            </p>
                            <a href="#" class="btn btn-default add-to-cart"><i class="fa fa-shopping-cart"></i>Add to cart</a>
                        </div>

                    </div>
                </div>
            </div>
        </div>
        <div class="item">
            <div class="col-sm-3">
                <div class="product-image-wrapper">
                    <div class="single-products">
                        <div class="productinfo text-center">
                            <img src="img/home/recommend1.jpg" alt="" />
                            <h2>$56</h2>
                            <p>
                                Easy Polo Black Edition
                            </p>
                            <a href="#" class="btn btn-default add-to-cart"><i class="fa fa-shopping-cart"></i>Add to cart</a>
                        </div>

                    </div>
                </div>
            </div>
            <div class="col-sm-3">
                <div class="product-image-wrapper">
                    <div class="single-products">
                        <div class="productinfo text-center">
                            <img src="img/home/recommend2.jpg" alt="" />
                            <h2>$56</h2>
                            <p>
                                Easy Polo Black Edition
                            </p>
                            <a href="#" class="btn btn-default add-to-cart"><i class="fa fa-shopping-cart"></i>Add to cart</a>
                        </div>

                    </div>
                </div>
            </div>
            <div class="col-sm-3">
                <div class="product-image-wrapper">
                    <div class="single-products">
                        <div class="productinfo text-center">
                            <img src="img/home/recommend3.jpg" alt="" />
                            <h2>$56</h2>
                            <p>
                                Easy Polo Black Edition
                            </p>
                            <a href="#" class="btn btn-default add-to-cart"><i class="fa fa-shopping-cart"></i>Add to cart</a>
                        </div>

                    </div>
                </div>
            </div>
        </div>
    </div>
    <a class="left recommended-item-control" href="#recommended-item-carousel" data-slide="prev"> <i class="fa fa-angle-left"></i> </a>
    <a class="right recommended-item-control" href="#recommended-item-carousel" data-slide="next"> <i class="fa fa-angle-right"></i> </a>
</div>
SUNIL KUMAR EU
quelle
-1

Sie können mehrere li in ol-Tags hinzufügen, die ein Attribut als Klasse mit dem Wert "Karussellindikatoren" und mit Daten-Folie zu sequentiellen Werten wie 0 bis 6 oder 0 bis 9 haben.

dann müssen Sie nur das div kopieren und einfügen, das das Attribut als Klasse mit dem Wert "item" hat.

Das funktioniert bei mir.

<div data-ride="carousel" class="carousel slide" id="myCarousel">
    <!-- Indicators -->
    <ol class="carousel-indicators">
        <li class="" data-slide-to="0" data-target="#myCarousel"></li>
        <li data-slide-to="1" data-target="#myCarousel" class=""></li>
        <li data-slide-to="2" data-target="#myCarousel" class="active"></li>
        <li data-slide-to="3" data-target="#myCarousel" class=""></li>
        <li data-slide-to="4" data-target="#myCarousel" class=""></li>
        <li data-slide-to="5" data-target="#myCarousel" class=""></li>
        <li data-slide-to="6" data-target="#myCarousel" class=""></li>
    </ol>
    <div role="listbox" class="carousel-inner">
        <div class="item active">
            <img alt="First slide" src="images/carousel/11.jpg"
                class="first-slide">
        </div>
        <div class="item">
            <img alt="Second slide" src="images/carousel/22.jpg"
                class="second-slide">
        </div>
        <div class="item">
            <img alt="Third slide" src="images/carousel/33.jpg"
                class="third-slide">
        </div>
        <div class="item">
            <img alt="Third slide" src="images/carousel/44.jpeg"
                class="fourth-slide">
        </div>
        <div class="item">
            <img alt="Third slide" src="images/carousel/55.jpg"
                class="third-slide">
        </div>
        <div class="item">
            <img alt="Third slide" src="images/carousel/66.jpg"
                class="third-slide">
        </div>
        <div class="item">
            <img alt="Third slide" src="images/carousel/77.jpg"
                class="third-slide">
        </div>
    </div>
    <a data-slide="prev" role="button" href="#myCarousel"
        class="left carousel-control"> <span aria-hidden="true"
        class="glyphicon glyphicon-chevron-left"></span> <span
        class="sr-only">Previous</span>
    </a> <a data-slide="next" role="button" href="#myCarousel"
        class="right carousel-control"> <span aria-hidden="true"
        class="glyphicon glyphicon-chevron-right"></span> <span
        class="sr-only">Next</span>
    </a>
</div>
Hemant_R_D
quelle
1
Kannst du uns ein Bootply zeigen? es funktioniert nicht und ich verstehe nicht, was du hier machen willst?
Azerafati
-1

Verweis auf den obigen Link Ich habe 1 neues Ding namens Show 4 hinzugefügt. Folie eins nach dem anderen für Bootstrap 3 (v3.3.7).

CODEPLY : - https://www.codeply.com/go/eWUbGlspqU

LIVE SNIPPET

(function(){
  $('#carousel123').carousel({ interval: 2000 });
}());

(function(){
  $('.carousel-showmanymoveone .item').each(function(){
    var itemToClone = $(this);

    for (var i=1;i<4;i++) {
      itemToClone = itemToClone.next();

      // wrap around if at end of item collection
      if (!itemToClone.length) {
        itemToClone = $(this).siblings(':first');
      }

      // grab item, clone, add marker class, add to collection
      itemToClone.children(':first-child').clone()
        .addClass("cloneditem-"+(i))
        .appendTo($(this));
    }
  });
}());
body {
    margin-top: 50px;
}

.carousel-showmanymoveone .carousel-control {
  width: 4%;
  background-image: none;
}
.carousel-showmanymoveone .carousel-control.left {
  margin-left: 15px;
}
.carousel-showmanymoveone .carousel-control.right {
  margin-right: 15px;
}
.carousel-showmanymoveone .cloneditem-1,
.carousel-showmanymoveone .cloneditem-2,
.carousel-showmanymoveone .cloneditem-3 {
  display: none;
}
@media all and (min-width: 768px) {
  .carousel-showmanymoveone .carousel-inner > .active.left,
  .carousel-showmanymoveone .carousel-inner > .prev {
    left: -50%;
  }
  .carousel-showmanymoveone .carousel-inner > .active.right,
  .carousel-showmanymoveone .carousel-inner > .next {
    left: 50%;
  }
  .carousel-showmanymoveone .carousel-inner > .left,
  .carousel-showmanymoveone .carousel-inner > .prev.right,
  .carousel-showmanymoveone .carousel-inner > .active {
    left: 0;
  }
  .carousel-showmanymoveone .carousel-inner .cloneditem-1 {
    display: block;
  }
}
@media all and (min-width: 768px) and (transform-3d), all and (min-width: 768px) and (-webkit-transform-3d) {
  .carousel-showmanymoveone .carousel-inner > .item.active.right,
  .carousel-showmanymoveone .carousel-inner > .item.next {
    -webkit-transform: translate3d(50%, 0, 0);
            transform: translate3d(50%, 0, 0);
    left: 0;
  }
  .carousel-showmanymoveone .carousel-inner > .item.active.left,
  .carousel-showmanymoveone .carousel-inner > .item.prev {
    -webkit-transform: translate3d(-50%, 0, 0);
            transform: translate3d(-50%, 0, 0);
    left: 0;
  }
  .carousel-showmanymoveone .carousel-inner > .item.left,
  .carousel-showmanymoveone .carousel-inner > .item.prev.right,
  .carousel-showmanymoveone .carousel-inner > .item.active {
    -webkit-transform: translate3d(0, 0, 0);
            transform: translate3d(0, 0, 0);
    left: 0;
  }
}
@media all and (min-width: 992px) {
  .carousel-showmanymoveone .carousel-inner > .active.left,
  .carousel-showmanymoveone .carousel-inner > .prev {
    left: -25%;
  }
  .carousel-showmanymoveone .carousel-inner > .active.right,
  .carousel-showmanymoveone .carousel-inner > .next {
    left: 25%;
  }
  .carousel-showmanymoveone .carousel-inner > .left,
  .carousel-showmanymoveone .carousel-inner > .prev.right,
  .carousel-showmanymoveone .carousel-inner > .active {
    left: 0;
  }
  .carousel-showmanymoveone .carousel-inner .cloneditem-2,
  .carousel-showmanymoveone .carousel-inner .cloneditem-3 {
    display: block;
  }
}
@media all and (min-width: 992px) and (transform-3d), all and (min-width: 992px) and (-webkit-transform-3d) {
  .carousel-showmanymoveone .carousel-inner > .item.active.right,
  .carousel-showmanymoveone .carousel-inner > .item.next {
    -webkit-transform: translate3d(25%, 0, 0);
            transform: translate3d(25%, 0, 0);
    left: 0;
  }
  .carousel-showmanymoveone .carousel-inner > .item.active.left,
  .carousel-showmanymoveone .carousel-inner > .item.prev {
    -webkit-transform: translate3d(-25%, 0, 0);
            transform: translate3d(-25%, 0, 0);
    left: 0;
  }
  .carousel-showmanymoveone .carousel-inner > .item.left,
  .carousel-showmanymoveone .carousel-inner > .item.prev.right,
  .carousel-showmanymoveone .carousel-inner > .item.active {
    -webkit-transform: translate3d(0, 0, 0);
            transform: translate3d(0, 0, 0);
    left: 0;
  }
}
<link rel="stylesheet" href="https://maxcdn.bootstrapcdn.com/bootstrap/3.3.7/css/bootstrap.min.css">

<div class="carousel carousel-showmanymoveone slide" id="carousel123">
	<div class="carousel-inner">
		<div class="item active">
			<div class="col-xs-12 col-sm-6 col-md-3"><a href="#"><img src="http://placehold.it/500/0054A6/fff/&amp;text=1" class="img-responsive"></a></div>
		</div>
		<div class="item">
			<div class="col-xs-12 col-sm-6 col-md-3"><a href="#"><img src="http://placehold.it/500/002d5a/fff/&amp;text=2" class="img-responsive"></a></div>
		</div>
		<div class="item">
			<div class="col-xs-12 col-sm-6 col-md-3"><a href="#"><img src="http://placehold.it/500/d6d6d6/333&amp;text=3" class="img-responsive"></a></div>
		</div>          
		<div class="item">
			<div class="col-xs-12 col-sm-6 col-md-3"><a href="#"><img src="http://placehold.it/500/002040/eeeeee&amp;text=4" class="img-responsive"></a></div>
		</div>
		<div class="item">
			<div class="col-xs-12 col-sm-6 col-md-3"><a href="#"><img src="http://placehold.it/500/0054A6/fff/&amp;text=5" class="img-responsive"></a></div>
		</div>
		<div class="item">
			<div class="col-xs-12 col-sm-6 col-md-3"><a href="#"><img src="http://placehold.it/500/002d5a/fff/&amp;text=6" class="img-responsive"></a></div>
		</div>
		<div class="item">
			<div class="col-xs-12 col-sm-6 col-md-3"><a href="#"><img src="http://placehold.it/500/eeeeee&amp;text=7" class="img-responsive"></a></div>
		</div>
		<div class="item">
			<div class="col-xs-12 col-sm-6 col-md-3"><a href="#"><img src="http://placehold.it/500/40a1ff/002040&amp;text=8" class="img-responsive"></a></div>
		</div>
	</div>
	<a class="left carousel-control" href="#carousel123" data-slide="prev"><i class="glyphicon glyphicon-chevron-left"></i></a>
	<a class="right carousel-control" href="#carousel123" data-slide="next"><i class="glyphicon glyphicon-chevron-right"></i></a>
</div>

<script src="https://code.jquery.com/jquery-3.3.1.min.js"></script>
<script src="https://maxcdn.bootstrapcdn.com/bootstrap/3.3.7/js/bootstrap.min.js"></script>

Nisharg Shah
quelle