Manuel Roccon

ICT & Cyber Security Specialist

Bootstrap 4 – lightbox 2 e thumbnails in carousel

Carousel è il componente per permettere lo slideshow delle immagini. Il componente non è però fornito la funzione di anteprima delle immagini e senza anteprima di navigazione.

https://getbootstrap.com/docs/4.0/components/carousel/

Lightbox 2

Un componente che ho usato molto per questo scopo è LIGHTBOX 2.

https://lokeshdhakar.com/projects/lightbox2/#getting-started

Il componente prevede di inserire un tag <a> tra l’immagine in cui si desidera l’anteprima, purtroppo eseguendo questo il componente smette di funzionare.

Per risolvere la cosa è molto semplice, è necessario sostituire il <div> che racchiude l’immagine con un tag <a> mantenendo tutte le classi. A questo punto i componenti riprenderanno a funzionare entrambi.

Qui sotto il codice originale:

&lt;!--Carousel Wrapper-->
&lt;div id="carousel" class="carousel slide carousel-fade" data-ride="carousel">
    
    &lt;!--Slides-->
    &lt;div class="carousel-inner">
        &lt;div class="carousel-item active">
            &lt;div class="carousel-img-container d-flex justify-content-center">
                &lt;img class="d-block w-100" src="path_to_file" alt="First slide">
             &lt;/div>
         &lt;/div>
         &lt;div class="carousel-item">
             &lt;div class="carousel-img-container d-flex justify-content-center">
                 &lt;img class="d-block w-100" src="path_to_file" alt="Second slide">
             &lt;/div>
         &lt;/div>
     &lt;/div>
    &lt;!--/.Slides-->
    
    &lt;!--Controls-->
    &lt;a class="carousel-control-prev" href="#carousel" role="button" data-slide="prev">
        &lt;span class="carousel-control-prev-icon" aria-hidden="true">&lt;/span>
        &lt;span class="sr-only">Previous&lt;/span>
    &lt;/a>
    &lt;a class="carousel-control-next" href="#carousel" role="button" data-slide="next">
        &lt;span class="carousel-control-next-icon" aria-hidden="true">&lt;/span>
        &lt;span class="sr-only">Next&lt;/span>
    &lt;/a>
    &lt;!--/.Controls-->

&lt;/div>

Questo è il codice con integrato lightbox:

&lt;!--Carousel Wrapper-->
&lt;div id="carousel" class="carousel slide carousel-fade" data-ride="carousel">
    
    &lt;!--Slides-->
    &lt;div class="carousel-inner">
        &lt;div class="carousel-item active">
            &lt;a href="path_to_file" data-lightbox="roadtrip" class="carousel-img-container d-flex justify-content-center">
                &lt;img class="d-block w-100" src="path_to_file" alt="First slide">
            &lt;/a>
        &lt;/div>
        &lt;div class="carousel-item">
            &lt;a href="path_to_file" data-lightbox="roadtrip" class="carousel-img-container d-flex justify-content-center">
                &lt;img class="d-block w-100" src="path_to_file" alt="Second slide">
             &lt;/a>
         &lt;/div>
    &lt;/div>
    &lt;!--/.Slides-->
    
    &lt;!--Controls-->
    &lt;a class="carousel-control-prev" href="#carousel" role="button" data-slide="prev">
        &lt;span class="carousel-control-prev-icon" aria-hidden="true">&lt;/span>
        &lt;span class="sr-only">Previous&lt;/span>
    &lt;/a>
    &lt;a class="carousel-control-next" href="#carousel" role="button" data-slide="next">
        &lt;span class="carousel-control-next-icon" aria-hidden="true">&lt;/span>
        &lt;span class="sr-only">Next&lt;/span>
    &lt;/a>
    &lt;!--/.Controls-->

&lt;/div>

A questo punto i 2 componenti funzioneranno perfettamente assieme.

Thumbnail

A questo punto avevo necessità di integrare anche delle anteprime cliccabili.

Qui sotto una variante del componente originale con aggiunta le anteprime navigabili:

HTML

&lt;!--Carousel Wrapper-->
&lt;div id="carousel-thumb" class="carousel slide carousel-fade carousel-thumbnails" data-ride="carousel">
    &lt;!--Slides-->
    &lt;div class="carousel-inner" role="listbox">
        &lt;div class="carousel-item active">
            &lt;img class="d-block w-100" src="https://s3-us-west-2.amazonaws.com/s.cdpn.io/252820/1320x580-77.jfif" alt="First slide">
        &lt;/div>
        &lt;div class="carousel-item">
            &lt;img class="d-block w-100" src="https://s3-us-west-2.amazonaws.com/s.cdpn.io/252820/1320x580-74.jfif" alt="Second slide">
        &lt;/div>
        &lt;div class="carousel-item">
            &lt;img class="d-block w-100" src="https://s3-us-west-2.amazonaws.com/s.cdpn.io/252820/1320x580-78.jfif" alt="Third slide">
        &lt;/div>
    &lt;/div>
    &lt;!--/.Slides-->
    &lt;!--Controls-->
    &lt;a class="carousel-control-prev" href="#carousel-thumb" role="button" data-slide="prev">
        &lt;span class="carousel-control-prev-icon" aria-hidden="true">&lt;/span>
        &lt;span class="sr-only">Previous&lt;/span>
    &lt;/a>
    &lt;a class="carousel-control-next" href="#carousel-thumb" role="button" data-slide="next">
        &lt;span class="carousel-control-next-icon" aria-hidden="true">&lt;/span>
        &lt;span class="sr-only">Next&lt;/span>
    &lt;/a>
    &lt;!--/.Controls-->
    &lt;ol class="carousel-indicators">
        &lt;li data-target="#carousel-thumb" data-slide-to="0" class="active"> &lt;img class="d-block w-100" src="https://s3-us-west-2.amazonaws.com/s.cdpn.io/252820/1320x580-77.jfif" class="img-fluid">&lt;/li>
        &lt;li data-target="#carousel-thumb" data-slide-to="1">&lt;img class="d-block w-100" src="https://s3-us-west-2.amazonaws.com/s.cdpn.io/252820/1320x580-74.jfif" class="img-fluid">&lt;/li>
        &lt;li data-target="#carousel-thumb" data-slide-to="2">&lt;img class="d-block w-100" src="https://s3-us-west-2.amazonaws.com/s.cdpn.io/252820/1320x580-78.jfif" class="img-fluid">&lt;/li>
    &lt;/ol>
&lt;/div>
&lt;!--/.Carousel Wrapper-->

CSS

.carousel-thumbnails .carousel-indicators img {
    max-width: 100px;
    height: 50px;
    overflow: hidden;
    display: block;
}


.carousel-thumbnails .carousel-indicators li {
    height: auto;
    max-width: 100px;
    width: 100px;
    border: none;
	box-shadow: 1px 3px 5px 0px rgba(0,0,0,0.75);
	
	&amp;.active {
		border-bottom: 4px solid #fff;
	}
}

Lascia un commento

Il tuo indirizzo email non sarà pubblicato. I campi obbligatori sono contrassegnati *