Ce guide vous explique comment créer des animations CSS hautes performances.
Consultez la section Pourquoi certaines animations sont-elles lentes ? pour en savoir plus sur la théorie sous-jacente de ces recommandations.
Compatibilité du navigateur
Toutes les propriétés CSS recommandées dans ce guide sont compatibles avec tous les navigateurs.
transform
opacity
will-change
Déplacer un élément
Pour déplacer un élément, utilisez les valeurs de mot clé translate
ou rotation
de la propriété transform
.
Par exemple, pour faire glisser un élément dans la vue, utilisez translate
.
.animate {
animation: slide-in 0.7s both;
}
@keyframes slide-in {
0% {
transform: translateY(-1000px);
}
100% {
transform: translateY(0);
}
}
Utilisez rotate
pour faire pivoter les éléments. L'exemple suivant fait pivoter un élément de 360 degrés.
.animate {
animation: rotate 0.7s ease-in-out both;
}
@keyframes rotate {
0% {
transform: rotate(0);
}
100% {
transform: rotate(360deg);
}
}
Redimensionner un élément
Pour redimensionner un élément, utilisez la valeur du mot clé scale
de la propriété transform
.
.animate {
animation: scale 1.5s both;
}
@keyframes scale {
50% {
transform: scale(0.5);
}
100% {
transform: scale(1);
}
}
Modifier la visibilité d'un élément
Pour afficher ou masquer un élément, utilisez opacity
.
.animate {
animation: opacity 2.5s both;
}
@keyframes opacity {
0% {
opacity: 1;
}
50% {
opacity: 0;
}
100% {
opacity: 1;
}
}
Éviter les propriétés qui déclenchent la mise en page ou la peinture
Avant d'utiliser une propriété CSS pour l'animation (autre que transform
et opacity
), déterminez son impact sur le pipeline de rendu.
Évitez toute propriété qui déclenche la mise en page ou la peinture, sauf en cas d'absolue nécessité.
Forcer la création du calque
Comme expliqué dans Pourquoi certaines animations sont-elles lentes ?, placer des éléments sur une nouvelle couche permet au navigateur de les repeindre sans avoir à repeindre le reste de la mise en page.
Les navigateurs peuvent généralement prendre de bonnes décisions sur les éléments à placer sur une nouvelle couche, mais vous pouvez forcer manuellement la création de couches avec la propriété will-change
.
Comme son nom l'indique, cette propriété indique au navigateur que cet élément va être modifié d'une manière ou d'une autre.
En CSS, vous pouvez appliquer will-change
à n'importe quel sélecteur :
body > .sidebar {
will-change: transform;
}
Toutefois, la spécification suggère de ne le faire que pour les éléments qui sont toujours sur le point de changer. Par exemple, cela peut être le cas pour une barre latérale que l'utilisateur peut faire glisser. Pour les éléments qui ne changent pas fréquemment, nous vous recommandons d'appliquer will-change
à l'aide de JavaScript lorsqu'un changement est susceptible de se produire. Assurez-vous de laisser au navigateur suffisamment de temps pour effectuer les optimisations nécessaires, puis supprimez la propriété lorsque le changement est terminé.
Si vous souhaitez forcer la création de calques dans un navigateur qui n'est pas compatible avec will-change
(Internet Explorer, par exemple), vous pouvez définir transform: translateZ(0)
.
Déboguer les animations lentes ou glitchs
Les outils pour les développeurs Chrome et Firefox disposent de nombreux outils pour vous aider à comprendre pourquoi vos animations sont lentes ou présentent des problèmes.
Vérifier si une animation déclenche une mise en page
Une animation qui déplace un élément à l'aide d'un élément autre que transform
est susceptible d'être lente. L'exemple suivant compare une animation utilisant transform
à une animation utilisant top
et 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)); } }
Vous pouvez le tester dans les deux exemples Glitch suivants et explorer les performances à l'aide de DevTools.
Outils pour les développeurs Chrome
- Ouvrez le panneau Performances.
- Enregistrez les performances d'exécution pendant l'exécution de votre animation.
- Examinez l'onglet Résumé.
Si une valeur non nulle s'affiche pour Rendering (Rendu) dans l'onglet Summary (Récapitulatif), cela peut signifier que votre animation oblige le navigateur à effectuer des tâches de mise en page.
Outils de développement Firefox
Dans les outils de développement Firefox, la cascade peut vous aider à comprendre où le navigateur passe son temps.
- Ouvrez le panneau Performances.
- Commencez à enregistrer les performances pendant la lecture de votre animation.
- Arrêtez l'enregistrement et inspectez l'onglet Cascade.
Si des entrées pour Recalculate Style (Recalculer le style) s'affichent, cela signifie que le navigateur doit revenir au début de la cascade de rendu pour afficher l'animation.
Vérifier les pertes de frames
- Ouvrez l'onglet Rendering (Rendu) dans les outils pour les développeurs Chrome.
- Cochez la case Compteur FPS.
- Observez les valeurs pendant l'exécution de l'animation.
Notez l'étiquette Frames (Cadres) en haut de l'interface utilisateur du mètre de FPS.
Des valeurs telles que 50% 1 (938 m) dropped of 1878
s'affichent. Une animation hautes performances affiche un pourcentage élevé, comme 99%
, ce qui signifie que peu de frames sont abandonnés et que l'animation est fluide.
Vérifier si une animation déclenche la peinture
Certaines propriétés sont plus coûteuses à peindre pour le navigateur que d'autres. Par exemple, tout ce qui implique un flou (comme une ombre, par exemple) prend plus de temps à peindre qu'à dessiner une boîte rouge. Ces différences ne sont pas toujours évidentes dans le CSS, mais les outils de développement du navigateur peuvent vous aider à identifier les zones à repeindre, ainsi que d'autres problèmes de performances liés à la peinture.
Outils pour les développeurs Chrome
- Ouvrez l'onglet Rendu dans les outils pour les développeurs Chrome.
- Sélectionnez Flashing de peinture.
- Déplacez le pointeur sur l'écran.
Si l'ensemble de l'écran clignote ou que des zones sont mises en surbrillance qui ne devraient pas l'être, examinez la situation plus en détail.
Si vous devez déterminer si une propriété particulière est à l'origine de problèmes de performances liés à la peinture, le profileur de peinture dans les outils pour les développeurs Chrome peut vous aider.
Outils de développement Firefox
- Ouvrez Paramètres, puis ajoutez un bouton de boîte à outils pour Activer/Désactiver le clignotement de la peinture.
- Sur la page que vous souhaitez inspecter, activez le bouton et déplacez la souris ou faites défiler la page pour voir les zones en surbrillance.
Conclusion
Dans la mesure du possible, limitez les animations à opacity
et transform
pour les conserver à l'étape de composition du chemin de rendu. Utilisez les outils de développement pour vérifier quelle étape du chemin est affectée par vos animations.
Utilisez le profileur de peinture pour voir si des opérations de peinture sont particulièrement coûteuses. Si vous trouvez quelque chose, vérifiez si une autre propriété CSS offre le même aspect avec de meilleures performances.
Utilisez la propriété will-change
avec parcimonie et uniquement si vous rencontrez un problème de performances.