Transizioni

Quando interagisci con un sito web, potresti notare che molti elementi sono contrassegnati da uno stato. Ad esempio, i menu a discesa possono essere in stato aperto o chiuso. I pulsanti potrebbero cambiare colore quando vengono visualizzati o passati il mouse sopra. I modali appaiono e scompaiono.

Per impostazione predefinita, il CSS cambia subito lo stile di questi stati.

Utilizzando le transizioni CSS, è possibile interpolare lo stato iniziale e quello di destinazione dell'elemento. La transizione tra i due migliora l'esperienza utente, fornendo indicazioni visive, supporto e suggerimenti sulla causa e sull'effetto dell'interazione.

Proprietà della transizione

Supporto dei browser

  • Chrome: 26.
  • Edge: 12.
  • Firefox: 16.
  • Safari: 9.

Origine

Per utilizzare le transizioni in CSS, puoi usare le varie proprietà della transizione o la proprietà abbreviata transition.

proprietà-di-transizione

La proprietà transition-property specifica gli stili di cui eseguire la transizione.

.my-element {
  transition-property: background-color;
}

transition-property accetta uno o più nomi di proprietà CSS in un elenco separato da virgole.

Se vuoi, puoi utilizzare transition-property: all per indicare che ogni proprietà deve eseguire la transizione.

transition-duration

La proprietà transition-duration viene utilizzata per definire il tempo necessario per il completamento di una transizione.

transition-duration accetta unità di tempo, in secondi (s) o millisecondi (ms), e il valore predefinito è 0s.

transition-timing-function

Utilizza la proprietà transition-timing-function per variare la velocità di una transizione CSS nel corso di transition-duration.

Per impostazione predefinita, il CSS eseguirà la transizione degli elementi a una velocità costante (transition-timing-function: linear). Tuttavia, le transizioni lineari possono sembrare in qualche modo artificiali: nella vita reale, gli oggetti hanno un peso e non possono fermarsi e avviarsi all'istante. Accendere o uscire da una transizione può rendere le tue transizioni più vivaci e naturali.

Il nostro modulo sull'animazione CSS offre un'utile panoramica delle funzioni di temporizzazione.

Puoi utilizzare DevTools per sperimentare diverse funzioni di temporizzazione in tempo reale.

Editor dei tempi di transizione visiva di Chrome DevTools.

ritardo della transizione

Utilizza la proprietà transition-delay per specificare il momento in cui inizierà una transizione. Se transition-duration non è specificato, le transizioni inizieranno immediatamente perché il valore predefinito è 0s. Questa proprietà accetta un'unità di tempo, ad esempio secondi (s) o millisecondi (ms).

Questa proprietà è utile per le transizioni sfalsate, ottenuta impostando un valore transition-delay più lungo per ogni elemento successivo di un gruppo.

transition-delay è utile anche per il debug. L'impostazione del ritardo su un valore negativo può avviare una transizione più avanti nella sequenza temporale.

abbreviazione: transizione

Come la maggior parte delle proprietà CSS, esiste una versione breve. transition combina transition-property, transition-duration, transition-timing-function e transition-delay.

.longhand {
  transition-property: transform;
  transition-duration: 300ms;
  transition-timing-function: ease-in-out;
  transition-delay: 0s;
}

.shorthand {
  transition: transform 300ms ease-in-out 0s;
}

Quali elementi non possono essere sottoposti a transizione?

Durante la scrittura di codice CSS, puoi specificare le proprietà che devono avere transizioni animate. Consulta questo elenco MDN di proprietà CSS animabili.

In generale, è possibile eseguire la transizione solo di elementi che possono avere uno "stato intermedio" tra il loro stato iniziale e quello finale. Ad esempio, è impossibile aggiungere transizioni per font-family, perché non è chiaro quale "stato intermedio" tra serif e monospace dovrebbe essere simile a questo. D'altra parte, è possibile aggiungere transizioni per font-size perché la sua unità è una lunghezza interpolabile.

Diagramma di forme che passano facilmente da uno stato all'altro e due righe di testo in caratteri diversi di cui non è possibile effettuare una transizione uniforme.

Di seguito sono riportate alcune proprietà comuni di cui puoi eseguire la transizione.

Trasforma

Supporto dei browser

  • Chrome: 36.
  • Edge: 12.
  • Firefox: 16.
  • Safari: 9.

Origine

La transizione della proprietà CSS transform viene spesso eseguita perché si tratta di una proprietà con accelerazione GPU che garantisce un'animazione più fluida con un consumo inferiore di batteria. Questa proprietà ti consente di scalare, ruotare, traslare o disallineare arbitrariamente un elemento.

Consulta la sezione sulle trasformazioni nel nostro modulo Funzioni.

Colore

Prima, durante e dopo l'interazione, il colore può essere un ottimo indicatore dello stato. Ad esempio, un pulsante potrebbe cambiare colore se viene passato il mouse sopra. Questa modifica del colore può indicare all'utente che è possibile fare clic sul pulsante.

Le proprietà color, background-color e border-color sono solo alcuni dei punti in cui il colore può la transizione al momento dell'interazione.

Dai un'occhiata al nostro modulo sui colori.

Ombre

Le ombre vengono spesso modificate per indicare un cambiamento di altitudine, ad esempio per indicare il focus dell'utente.

Dai un'occhiata al nostro modulo sulle ombre.

Filtri

filter è una potente proprietà CSS che ti consente di aggiungere all'istante effetti grafici. Il passaggio tra diversi stati filter può generare risultati davvero impressionanti.

Consulta il nostro modulo sui filtri.

Attivatori di transizione

Il CSS deve includere un cambio di stato e un evento che attivi il cambio di stato per l'attivazione delle transizioni CSS. Un esempio tipico di questo trigger è la pseudo-classe :hover. Questa pseudo-classe corrisponde quando l'utente passa il mouse sopra un elemento con il cursore.

Di seguito è riportato un elenco di alcune pseudo-classi ed eventi che possono attivare modifiche di stato nei tuoi elementi.

  • :hover: trova se il cursore si trova sopra l'elemento.
  • :focus: corrisponde se l'elemento è attivo.
  • :focus-within : trova corrispondenze se l'elemento o i suoi discendenti sono specifici.
  • :target: trova corrispondenze quando il frammento dell'URL corrente corrisponde all'ID dell'elemento.
  • :active: corrisponde a quando l'elemento viene attivato (in genere quando l'elemento il mouse è premuto).
  • class cambia da JavaScript: quando il CSS class di un elemento cambia tramite JavaScript, il CSS eseguirà la transizione delle proprietà idonee che sono state modificate.

Transizioni diverse per entrare o uscire

Impostando proprietà transition diverse per il passaggio del mouse o lo stato attivo, puoi creare alcuni effetti interessanti.

.my-element {
  background: red;

  /* This transition is applied on the "exit" transition */
  transition: background 2000ms ease-in;
}

.my-element:hover {
  background: blue;

  /* This transition is applied on the "enter" transition */
  transition: background 150ms ease;
}

Considerazioni sull'accessibilità

Le transizioni CSS non sono una soluzione adatta a tutti. Per alcune persone, le transizioni e le animazioni possono causare chinetosi o malessere. Per fortuna, il CSS dispone di una funzionalità multimediale chiamata prefers-reduced-motion che rileva se un utente ha indicato una preferenza di minore movimento dal dispositivo.

/*
  If the user has expressed their preference for
  reduced motion, then don't use transitions.
*/
@media (prefers-reduced-motion: reduce) {
  .my-element {
    transition: none;
  }
}

/*
  If the browser understands the media query and the user
  explicitly hasn't set a preference, then use transitions.
*/
@media (prefers-reduced-motion: no-preference) {
  .my-element {
    transition: transform 250ms ease;
  }
}

Consulta il nostro post del blog prefers-reduced-motion: A volte meno movimento è più per ulteriori informazioni su questa funzionalità multimediale.

Considerazioni sulle prestazioni

Quando lavori con le transizioni CSS, potresti riscontrare problemi di rendimento se aggiungi transizioni per determinate proprietà CSS. Ad esempio, quando le proprietà come width o height cambiano, spostano i contenuti nel resto della pagina. In questo modo il CSS deve calcolare le nuove posizioni per ogni elemento interessato per ogni frame della transizione. Se possibile, consigliamo di utilizzare invece proprietà come transform e opacity.

Consulta la nostra guida sulle animazioni CSS ad alte prestazioni per un approfondimento su questo argomento.

Verifica le tue conoscenze

Verifica le tue conoscenze sulle transizioni

Quale proprietà di transizione consente di specificare l'easing?

animation-ease
transition-cubic-bezier
transition-duration
transition-timing-function
transition-easing

La best practice prevede l'uso di transition-property: all

falso
true

È possibile eseguire la transizione di tutte le proprietà.

falso
true