Nessun risultato. Prova con un altro termine.
Guide
Notizie
Software
Tutorial

Effetto di dissolvenza su testo con HTML, CSS e JavaScript

Come creare un testo con effetto dissolvenza e ricomparsa dinamica utilizzando codice HTML, CSS e JavaScript
Come creare un testo con effetto dissolvenza e ricomparsa dinamica utilizzando codice HTML, CSS e JavaScript
Link copiato negli appunti

L'effetto di dissolvenza è un'animazione molto utilizzata per creare transizioni fluide e accattivanti. Può essere impiegato per attirare l'attenzione su elementi di testo, immagini o pulsanti, migliorando l'esperienza utente e rendendo l'interfaccia più dinamica.

Guida alla creazione di un testo con effetto dissolvenza animato

In questo tutorial affronteremo tutti i passaggi per la creazione di un semplice effetto di dissolvenza e ricomparsa su un testo, utilizzando HTML, CSS e JavaScript. L'obiettivo è quello di realizzare un'animazione che faccia scomparire e riapparire il testo a intervalli regolari, ottenendo un effetto di transizione fluido e gradevole.

Perché utilizzare l'effetto dissolvenza?

L'animazione di dissolvenza è una tecnica elegante per:

  • Evidenziare informazioni importanti.
  • Creare un effetto di suspense o attesa.
  • Migliorare la leggibilità di un testo alternandone la visibilità.
  • Rendere un sito più dinamico e moderno senza appesantire l'interfaccia.

Grazie all'utilizzo combinato di CSS JavaScript

Struttura del progetto

Per realizzare il nostro effetto, utilizzeremo:

  • HTML per la struttura della pagina e il testo da animare.
  • CSS per lo stile e la gestione della transizione di dissolvenza.
  • JavaScript per controllare la logica dell'animazione, alternando la visibilità del testo a intervalli regolari.
  • Vediamo ora come implementare il tutto.

    Creazione del file HTML

    Cominciamo con la struttura di base del nostro file HTML:

    <!DOCTYPE html>
    <html lang="it">
    <head>
        <meta charset="UTF-8">
        <meta name="viewport" content="width=device-width, initial-scale=1.0">
        <title>Testo con effetto dissolvenza</title>
        <style>
            body {
                font-family: Arial, sans-serif;
                text-align: center;
                display: flex;
                justify-content: center;
                align-items: center;
                height: 100vh;
                margin: 0;
    background-color: midnightblue;
            }
            #fadingText {
                font-size: 24px;
    text-transform: uppercase;
    color: white;
                font-weight: bold;
                opacity: 1;
                transition: opacity 1.5s ease-in-out;
            }
        </style>
    </head>
    <body>
        <div id="fadingText">Testo con effetto dissolvenza</div>
        <script>
            function fadeEffect() {
                let text = document.getElementById("fadingText");
                let visible = true;
                setInterval(() => {
                    visible = !visible;
                    text.style.opacity = visible ? "1" : "0";
                }, 2000);
            }
            window.addEventListener("load", fadeEffect);
        </script>
    </body>
    </html>

    HTML: la struttura della pagina

    Il codice HTML è molto semplice. Abbiamo:

    • Un div fadingText
    • Un blocco script

    CSS: la gestione della transizione

    Il CSS è fondamentale per creare un effetto visivamente fluido:

    • display: flex justify-content: center align-items: center
    • opacity: 1 transition: opacity 1.5s ease-in-out

    JavaScript: il controllo dell'animazione

    Il codice JavaScript utilizza:

    • setInterval()
    • opacity
    • Un event listener

    Personalizzazioni e varianti

    Una volta capito il funzionamento base, possiamo personalizzare l'effetto in vari modi. Ad esempio modificare la durata della dissolvenza. Se vogliamo rendere l'effetto più lento o più veloce, possiamo cambiare il valore di transition in CSS in questo modo:

    transition: opacity 2.5s ease-in-out; /* Effetto più lento */

    Cambiare la frequenza dell'animazione

    Per far sì che il testo cambi meno frequentemente, possiamo aumentare il valore di setInterval() in JavaScript:

    setInterval(() => {
        visible = !visible;
        text.style.opacity = visible ? "1" : "0";
    }, 4000); // Cambia ogni 4 secondi

    Applicare l'effetto a più elementi

    Se vogliamo che l'effetto sia applicato a più testi contemporaneamente possiamo utilizzare querySelectorAll e un ciclo forEach::

    function fadeEffect() {
        let texts = document.querySelectorAll(".fadeText");
        setInterval(() => {
            texts.forEach(text => {
                text.style.opacity = text.style.opacity == "1" ? "0" : "1";
            });
        }, 2000);
    }

    E nel nostro HTML possiamo avere più div con la classe fadeText:

    <div class="fadeText">Primo testo</div>
    <div class="fadeText">Secondo testo</div>
    <div class="fadeText">Terzo testo</div>

    Applicare l'effetto a più elementi in maniera alternata

    Se vogliamo che l'effetto sia applicato a più testi in maniera alternata, possiamo utilizzare:

    <script>
            function fadeEffect() {
                let texts = document.querySelectorAll(".fadeText");
                let index = 0;
                function showNextText() {
                    texts.forEach((text, i) => {
                        text.style.opacity = (i === index) ? "1" : "0";
                    });
                    index = (index + 1) % texts.length;
                }
                showNextText();
                setInterval(showNextText, 2000);
            }
            window.addEventListener("load", fadeEffect);
        </script>

    Conclusioni

    Abbiamo visto come creare un effetto di dissolvenza e ricomparsa dinamica su un testo utilizzando HTML, CSS e JavaScript. Questo tipo di animazione può essere utile per migliorare l'esperienza utente e rendere un sito web più accattivante senza appesantire il caricamento della pagina.
    Grazie alle possibilità di personalizzazione, puoi adattare l'effetto a diversi contesti e applicazioni. Prova a sperimentare con i tempi di transizione, il numero di elementi animati e altri effetti CSS per ottenere risultati ancora più interessanti.

Ti consigliamo anche