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
opacity
will-change
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
.
.box { position: absolute; top: 10px; left: 10px; animation: move 3s ease infinite; } @keyframes move { 50% { top: calc(90vh - 160px); left: calc(90vw - 200px); } }
.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
- Apri il riquadro Rendimento.
- Registrare le prestazioni di runtime durante l'animazione.
- 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.
.Firefox DevTools
In Firefox DevTools la funzionalità a cascata può aiutarti a capire su quali pagine il browser passa tempo.
- Apri il riquadro Rendimento.
- Inizia a registrare il rendimento durante l'animazione.
- 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
- Apri la scheda Rendering in Chrome DevTools.
- Attiva la casella di controllo Misuratore f/s.
- 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.
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
- Apri la scheda Rendering in Chrome DevTools.
- Seleziona Lampeggia la vernice.
- Sposta il puntatore sullo schermo.
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
- Apri Impostazioni e aggiungi un pulsante Strumenti per Attiva/disattiva la vernice lampeggiante.
- 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.