A poids égal un fichier javascript et une image n’ont pas le même coût pour le navigateur
En effet contrairement à une image, un fichier javascript devra être parsé et exécuté par le navigateur et monopolisera son thread principal en plus de son téléchargement. Il y a donc un véritable enjeu à diminuer le plus possible la quantité de javascript envoyée côté client.
L’optimisation des images reste néanmoins un sujet important, particulièrement sur mobile.
Étapes effectuées par le navigateur pour chaque fichier javascript
Deuxième constat en ce qui concerne les conséquences :
Il est courant de sous-estimer l’impact que représentent des problèmes de performances pour ses utilisateurs. Sans même parler de problèmes, améliorer ses performances peut apporter des gains significatifs. Pour en avoir une idée voici quelques statistiques qui illustrent ces impacts :
Les performances ont donc une corrélation directe avec les indicateurs business d’une application web. Pour plus de REX sur le thème des performances, vous pouvez consulter le site : wpostats.com
A noter cependant que ces résultats sont à prendre avec un peu de recul. Le temps de chargement par exemple est une métrique assez floue et pas forcément représentative de l’expérience utilisateur. Quant aux indicateurs business (conversion, traffic, chiffre d’affaire, etc.), ils sont soumis à de nombreux facteurs donc le rapprochement est plus difficile à mesurer. Néanmoins la corrélation établie reste indéniable.
Maintenant que vous êtes convaincu par l’utilité d’investir du temps sur la performance web, la question qui en découle naturellement est : comment traiter ces problèmes de performances ? Principalement en construisant une culture de la performance au sein de son équipe.
Commencer à s’attaquer à la problématique des performances n’est pas évident, surtout si la prise de conscience est récente. Introduire une culture sur ce sujet dans son équipe est la première étape pour anticiper ou réduire durablement une dégradation des performances.
L’objectif de cette étape est d’établir un premier bilan de l’état de son projet.
Lighthouse est un bon point de départ, accessible directement depuis les devtool chrome (via l’onglet audit), il vous fournira des métriques importantes ainsi que des propositions d’améliorations. Le First Contentful Paint par exemple correspond au premier affichage de texte ou d’image sur la page. Le Speed Index est aussi un bon indicateur, il représente la vitesse de remplissage de la page perçue par l’utilisateur.
Capture d’un audit effectué avec Lighthouse
A noter également, que Lighthouse vous fera aussi des recommandations en SEO, Accessibilité, Progressive web app et des bonnes pratiques.
Vous pouvez également implémenter vos propres métriques à l’aide de l’api window.performance. La méthode performance.mark() permet de poser un marqueur à un instant précis et la méthode performance.measure() de mesurer le temps entre 2 marqueurs (exemple). Cela peut vous permettre de mesurer de façon plus fine les parties de votre application importantes d’un point de vue fonctionnel. Une fois la méthode performance.measure() appelée votre métrique devrait apparaître dans les chrome dev tool.
Visualisation d’une métrique personnalisée dans les Chrome dev tool
Les sites comme Webpagetest ou gtmetrix vous permettront de lancer une série de tests sur une adresse publique. Si votre site/application est déjà en production et accessible il vous permettra d’obtenir d’autres informations complémentaires.
Capture d’une partie d’un audit sur Webpagetest
Cette étape est probablement la plus importante car elle permet d’intégrer la gestion des performances au quotidien. L’idée est d’intégrer des contrôles sur la CI pour pouvoir surveiller l’évolution de certaines métriques.
Une des premières métriques à mettre en place est la taille du bundle javascript de production. Le projet bundlesize vous permettra de la mettre en place sur votre CI (actuellement compatible avec Travis, CircleCI, Wercker et Drone).
Intégration de bundlesize dans une pull request
Cette métrique est à mettre en place le plus tôt possible car réduire un bundle volumineux est une tâche complexe. Dans les premières phases d’un projet, on a tendance à ajouter facilement des dépendances sans remettre en question leur coût. On va alors commencer à écrire du code qui les exploite, ce qui rendra leur remplacement/suppression de plus en plus coûteuse avec le temps. C’est pourquoi avant d’ajouter une nouvelle dépendance, il faut se demander si son coût est justifié. L’outil BundlePhobia peut être utilisé en complément. Il vous permet de connaître rapidement le poids d’un package ainsi que son temps de téléchargement en 2G et 3G. Il proposera également des alternatives si elles existent.
Ensuite il est possible d’automatiser les audits Lighthouse, sur une CI Travis par exemple avec ce projet.
Intégration de Lighthouse dans une pull request
Si vous n’utilisez par une CI Travis il existe d’autres alternatives, comme ce projet, qui sont indépendantes de la CI que vous utilisez et s’intégreront à vos pipelines existants.
Pour écrire des tests sur vos propres métriques il est possible d’utiliser Puppetter.
Pour cela il faut utiliser le Chrome Devtool Protocol (CDP) dont l’accès est facilité par puppeteer via la classe CDPSession.
Enfin il est également possible d’afficher directement le poids d’un module au moment de l’import dans l’éditeur. Des plugins sont disponibles pour VSCode, Atom, les IDE JetBrain et Vim. Ces extensions vont vous permettre de contrôler au plus tôt le coût de chaque dépendance dans votre projet.
Plugin import-cost pour VSCode
Il existe de nombreuses techniques pour travailler sur les performances, certaines seront globales et s’appliqueront à toutes vos pages d’autres seront plus des optimisations spécifiques par page.
Il peut être pertinent de se demander alors quelles sont les pages les plus visitées sur le site afin de concentrer ses efforts là où les utilisateurs en profiteront le plus.
Une fois ces pages identifiées, une bonne stratégie est de commencer par les “low hanging fruits” c’est-à-dire des améliorations qui ont un bon ratio temps investi/performance gagnée.
Le code splitting et le lazy loading sont des bons candidats pour des premiers chantiers, l’idée étant de gagner en confiance rapidement et de pouvoir communiquer sur ces premiers succès.
Exemples d’axes d’améliorations pour les performances web
Cette étape, qui n’est pas à négliger, va consister à communiquer au sein de l’équipe pour partager la connaissance et à l’extérieur de l’équipe pour valoriser les travaux effectués.
Les tâches d’optimisation doivent être partagées au sein de l’équipe, ainsi que leur résultat et les leçons à en tirer. C’est peut-être l’occasion de créer sa propre checklist de performance en incluant les liens des pull requests associées en guise d’exemple. Le plus important est que chaque personne se sente progressivement impliquée par la performance et puisse monter en compétence sur le sujet.
Travailler sur les performances prend néanmoins du temps, mais c’est du temps qui est largement justifié. Comme les bénéfices ne sont pas directement visibles, ils ne faut pas hésiter à communiquer sur les tâches effectuées aux personnes impliquées dans le projet mais également extérieures à l’équipe technique. Il est important aussi de constater ultérieurement les bénéfices sur les analytics qui valoriseront le temps investi. Enfin si des gros travaux sont engagés, il peut être pertinent de partager le savoir acquis et les résultats sous forme d’article public.
Dès maintenant
Dès que possible
Plus tard
Le sujet des performances est très vaste, de nombreux aspects n’ont pas été abordés dans cet article, mais travailler sur la mise en place d’une culture de performance paraît de plus en plus primordial. Elle doit vous aider à prendre en compte cet aspect au quotidien et à faire progresser l’équipe naturellement. Travailler sur les performances constitue une tâche à part entière dans le processus de développement et contribuera à élever la qualité logiciel de vos applications web.
Enfin il est aussi important et gratifiant de garder à l’esprit que tout le temps que vous économisez sur vos applications web est également du temps gagné par les utilisateurs, et ce à chaque utilisation !
Quelques liens pour aller plus loin :
Les trois types de tests de performance
Liste d’outils pour les performances