Come creare animazioni CSS ad alte prestazioni

Questa guida ti insegna come creare animazioni CSS ad alte prestazioni.

Consulta la sezione Perché alcune animazioni sono lente? per apprendere il alla base di questi consigli.

Compatibilità del browser

Tutte le proprietà CSS consigliate in questa guida sono valide per più browser assistenza in tempo reale.

transform

Supporto dei browser

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

Origine

opacity

Supporto dei browser

  • Chrome: 1.
  • Edge: 12.
  • Firefox: 1.
  • Safari: 2.

Origine

will-change

Supporto dei browser

  • Chrome: 36.
  • Edge: 79.
  • Firefox: 36.
  • Safari: 9.1.

Origine

Spostare un elemento

Per spostare un elemento, utilizza i valori delle parole chiave translate o rotation della transform.

Ad esempio, per visualizzare un elemento tramite scorrimento, utilizza translate.

.animate {
  animation: slide-in 0.7s both;
}

@keyframes slide-in {
  0% {
    transform: translateY(-1000px);
  }
  100% {
    transform: translateY(0);
  }
}

Usa rotate per ruotare gli elementi. Nell'esempio seguente viene ruotato un elemento 360 gradi.

.animate {
  animation: rotate 0.7s ease-in-out both;
}

@keyframes rotate {
  0% {
    transform: rotate(0);
  }
  100% {
    transform: rotate(360deg);
  }
}

Ridimensionare un elemento

Per ridimensionare un elemento, utilizza il valore della parola chiave scale dell'elemento transform.

.animate {
  animation: scale 1.5s both;
}

@keyframes scale {
  50% {
    transform: scale(0.5);
  }
  100% {
    transform: scale(1);
  }
}

Modificare la visibilità di un elemento

Per mostrare o nascondere un elemento, utilizza opacity.

.animate {
  animation: opacity 2.5s both;
}

@keyframes opacity {
  0% {
    opacity: 1;
  }
  50% {
    opacity: 0;
  }
  100% {
    opacity: 1;
  }
}

Evita le proprietà che attivano il layout o la colorazione

Prima di utilizzare qualsiasi proprietà CSS per l'animazione (diverse da transform e opacity), Determinare l'impatto della proprietà sulla pipeline di rendering. Evita qualsiasi proprietà che attivi il layout o il color, a meno che non sia assolutamente necessario.

Forza creazione dei livelli

Come spiegato nella sezione Perché alcune animazioni sono lente?, il posizionamento degli elementi su un nuovo livello consente al browser di ricrearli senza doverli ridipingere il resto del layout.

In genere i browser possono prendere buone decisioni su quali elementi posizionare su un ma puoi forzare manualmente la creazione di un livello con Proprietà will-change. Come suggerisce il nome, questa proprietà indica al browser che l'elemento verrà di essere modificato in qualche modo.

In CSS, puoi applicare will-change a qualsiasi selettore:

body > .sidebar {
  will-change: transform;
}

Tuttavia, la specifica consiglia di eseguire questa operazione solo per gli elementi che sono sempre in procinto di modifica. Ad esempio, ciò potrebbe essere vero per una barra laterale in cui l'utente può scorrere fuori. Per gli elementi che non cambiano di frequente, consigliamo di applicare will-change utilizzando JavaScript quando è probabile che si verifichi una modifica. Assicurati di concedi al browser il tempo sufficiente per eseguire le ottimizzazioni necessarie e rimuovi la proprietà quando la modifica è stata interrotta.

Se forzi la creazione dei livelli in un browser che non supporta will-change (molto probabilmente Internet Explorer), puoi impostare transform: translateZ(0).

Debug di animazioni lente o con glitch

Chrome DevTools e Firefox DevTools offrono molti strumenti utili per aiutarti a capire. perché le animazioni sono lente o con glitch.

Controllare se un'animazione attiva il layout

Un'animazione che sposta un elemento utilizzando qualcosa di diverso da transform è probabilmente sarà lento. L'esempio seguente mette a confronto un'animazione utilizzando transform a un'animazione utilizzando top e left.

Cosa non fare
.box {
  position: absolute;
  top: 10px;
  left: 10px;
  animation: move 3s ease infinite;
}

@keyframes move {
  50% {
     top: calc(90vh - 160px);
     left: calc(90vw - 200px);
  }
}
Cosa fare
.box {
  position: absolute;
  top: 10px;
  left: 10px;
  animation: move 3s ease infinite;
}

@keyframes move {
  50% {
     transform: translate(calc(90vw - 200px), calc(90vh - 160px));
  }
}

Puoi verificarlo nei due esempi seguenti: ed esplora le prestazioni con DevTools.

Chrome DevTools

  1. Apri il riquadro Rendimento.
  2. Registrare le prestazioni di runtime durante l'animazione.
  3. Esamina la scheda Riepilogo.

Se vedi un valore diverso da zero per il Rendering nella scheda Riepilogo, potrebbe significa che l'animazione fa funzionare il layout del browser.

Il riquadro Riepilogo mostra 37 ms per il rendering e 79 ms per la colorazione.
. L'animation-with-top-left causa il lavoro di rendering.
di Gemini Advanced.
.
. Il riquadro Riepilogo mostra valori pari a zero per il rendering e il disegno.
L'animazione-con-trasformazione dell'esempio non causa il lavoro di rendering.

Firefox DevTools

In Firefox DevTools la funzionalità a cascata può aiutarti a capire su quali pagine il browser passa tempo.

  1. Apri il riquadro Rendimento.
  2. Inizia a registrare il rendimento durante l'animazione.
  3. Interrompi la registrazione e controlla la scheda Struttura a cascata.

Se sono presenti voci per Ricalcola stile, significa che il browser deve tornare all'inizio cascata di rendering per eseguire il rendering dell'animazione.

Verifica la presenza di frame interrotti

  1. Apri la scheda Rendering in Chrome DevTools.
  2. Attiva la casella di controllo Misuratore f/s.
  3. Controlla i valori durante l'esecuzione dell'animazione.

Fai attenzione all'etichetta Frame nella parte superiore dell'interfaccia utente Strumento di misurazione f/s. Vengono mostrati valori quali 50% 1 (938 m) dropped of 1878. Un'architettura ad alte prestazioni animazione ha un'alta percentuale, ad esempio 99%, il che significa che pochi frame sono e l'animazione appare fluida.

Lo strumento di misurazione dei f/s mostra che il 50% dei frame è stato interrotto
. L'animation-with-top-left un esempio comporta l'eliminazione del 50% dei frame
Lo strumento di misurazione dei f/s mostra che solo l'1% dei fotogrammi è stato interrotto
. L'animazione-con-trasformazione Ad esempio, viene eliminato solo l'1% dei frame.

Controllare se un'animazione attiva la colorazione

Alcune proprietà sono più costose di altre da visualizzare nel browser. Per Ad esempio, tutto ciò che comporta una sfocatura (come un'ombra) aumenta dipingere che disegnare un riquadro rosso. Queste differenze non sono sempre evidenti nel CSS, ma il browser DevTools può aiutarti a identificare le aree che devono essere riverniciata e altri problemi di prestazioni legati alla verniciatura.

Chrome DevTools

  1. Apri la scheda Rendering in Chrome DevTools.
  2. Seleziona Lampeggia la vernice.
  3. Sposta il puntatore sullo schermo.
di Gemini Advanced.
Un elemento UI evidenziato in verde per dimostrare che verrà ridipinto
In questo esempio tratto da Google Maps, puoi vedere gli elementi che vengono ridipinti.

Se vedi lampeggiare l'intero schermo o aree evidenziate che non pensi devono cambiare, esamina ulteriormente.

Se devi stabilire se una determinata proprietà sta causando problemi di prestazioni correlati alla pittura, paint profiler in Chrome DevTools può aiutarti.

Firefox DevTools

  1. Apri Impostazioni e aggiungi un pulsante Strumenti per Attiva/disattiva la vernice lampeggiante.
  2. Nella pagina che vuoi controllare, attiva il pulsante e sposta il mouse o scorri per vedere le aree evidenziate.

Conclusione

Se possibile, limita le animazioni a opacity e transform per mantenerle nella fase di composizione del percorso di rendering. Utilizzare DevTools per verificare quale fase del percorso è interessata dalle animazioni.

Utilizza il profiler di colorazione per verificare se le operazioni di colorazione sono particolarmente costoso. Se trovi qualcosa, controlla se una proprietà CSS diversa offre lo stesso aspetto con prestazioni migliori.

Utilizza la proprietà will-change con parsimonia e solo in caso di problemi di prestazioni.