Découvrez ce qu'est le délai d'entrée et apprenez à le réduire afin d'accélérer l'interactivité.
Les interactions sur le Web sont complexes, car toutes sortes d'activités se produisent dans le navigateur pour les générer. Cependant, ils ont tous un point en commun : ils subissent un certain délai d'entrée avant que leurs rappels d'événement ne commencent à s'exécuter. Dans ce guide, vous allez découvrir ce qu'est le délai d'entrée et ce que vous pouvez faire pour le réduire afin que les interactions sur votre site Web s'exécutent plus rapidement.
Qu'est-ce que le délai d'entrée ?
Le délai de saisie correspond à la période écoulée entre le moment où l'utilisateur interagit avec une page (en appuyant sur un écran, en cliquant avec la souris ou en appuyant sur une touche, par exemple) jusqu'au moment où les rappels d'événement pour l'interaction commencent à s'exécuter. Chaque interaction commence par un certain délai d'entrée.
Une partie du délai d'entrée est inévitable: il faut toujours un certain temps au système d'exploitation pour reconnaître un événement d'entrée et le transmettre au navigateur. Toutefois, cette partie du délai d'entrée n'est généralement pas visible. D'autres événements peuvent survenir sur la page elle-même et ainsi entraîner des délais de saisie suffisamment longs pour provoquer des problèmes.
À propos du délai d'entrée
De manière générale, chaque partie d'une interaction doit être aussi courte que possible afin que votre site Web ait les meilleures chances d'atteindre la "bonnes" de la métrique Interaction to Next Paint (INP) : de sécurité, quel que soit l'appareil de l'utilisateur. Contrôler le délai d'entrée n'est qu'une partie de l'atteinte de ce seuil.
Par conséquent, vous devez chercher le délai d'entrée le plus court possible pour atteindre la valeur « bonne » de l'INP. de sortie. Sachez toutefois que vous ne pouvez pas vous attendre à éliminer complètement les délais d'entrée. Tant que vous évitez les tâches excessives du thread principal lorsque les utilisateurs tentent d'interagir avec votre page, le délai de saisie doit être suffisamment faible pour éviter les problèmes.
Réduire le délai d'entrée
Comme indiqué précédemment, un certain délai d'entrée est inévitable, tandis qu'un certain délai d'entrée est évitable. Voici quelques éléments à prendre en compte si vous rencontrez des problèmes avec de longs délais de saisie.
Éviter les minuteurs récurrents qui lancent un travail excessif du thread principal
En JavaScript, deux fonctions de minuterie couramment utilisées peuvent contribuer au délai d'entrée: setTimeout
et setInterval
. La différence entre les deux est que setTimeout
planifie un rappel pour qu'il s'exécute après un délai spécifié. setInterval
, en revanche, planifie un rappel pour qu'il s'exécute toutes les n millisecondes indéfiniment ou jusqu'à ce que le minuteur soit arrêté avec clearInterval
.
setTimeout
ne pose pas de problème en soi. Il peut même être utile pour éviter les longues tâches. Toutefois, cela dépend du moment où le délai d'inactivité s'est produit et de la tentative ou non d'interaction de l'utilisateur avec la page lors de l'exécution du rappel.
De plus, setTimeout
peut être exécuté dans une boucle ou de manière récursive, où il agit davantage comme setInterval
, mais de préférence, il ne planifie pas l'itération suivante tant que la précédente n'est pas terminée. Bien que cela signifie que la boucle cède au thread principal chaque fois que setTimeout
est appelé, vous devez veiller à ce que son rappel ne fasse pas un travail excessif.
setInterval
exécute un rappel sur un intervalle. Il est donc beaucoup plus susceptible de perturber les interactions. En effet, contrairement à une seule instance d'un appel setTimeout
, qui est un rappel ponctuel qui peut entraver une interaction avec l'utilisateur, la nature récurrente de setInterval
rend beaucoup plus susceptible d'entraver une interaction, ce qui augmente le délai d'entrée de l'interaction.
Si des minuteurs ont lieu dans le code propriétaire, c'est vous qui les contrôlez. Évaluez si vous en avez besoin ou faites de votre mieux pour les réduire autant que possible. Cependant, dans les scripts tiers, les minuteurs sont différents. Souvent, vous ne contrôlez pas le fonctionnement d'un script tiers. Pour résoudre les problèmes de performances dans le code tiers, vous devez souvent collaborer avec les personnes concernées pour déterminer si un script tiers donné est nécessaire. Si tel est le cas, contactez un fournisseur de script tiers pour déterminer comment résoudre les problèmes de performances qu'ils peuvent causer sur votre site Web.
Éviter les longues tâches
Une façon d'atténuer les longs délais d'entrée consiste à éviter les longues tâches. Lorsque des tâches de thread principal excessives bloquent le thread principal lors des interactions, cela s'ajoute au délai d'entrée avant que les longues tâches aient pu se terminer.
En plus de réduire la quantité de travail que vous effectuez dans une tâche (et vous devez toujours vous efforcer d'effectuer le moins de travail possible sur le thread principal), vous pouvez améliorer la réactivité aux entrées utilisateur en divisant les longues tâches.
Tenez compte des interactions et du chevauchement
Si vos interactions se chevauchent, l'optimisation de l'INP peut s'avérer particulièrement difficile. Le chevauchement d'interactions signifie qu'après avoir interagi avec un élément, vous effectuez une autre interaction avec la page avant que l'interaction initiale ait eu la possibilité d'afficher le frame suivant.
Les sources de chevauchement peuvent être aussi simples que les utilisateurs effectuant de nombreuses interactions dans un court laps de temps. Cela peut se produire lorsque les utilisateurs saisissent du texte dans des champs de formulaire, où de nombreuses interactions avec le clavier peuvent se produire en très peu de temps. Si le travail sur un événement clé est particulièrement coûteux (par exemple, dans le cas des champs de saisie semi-automatique où des requêtes réseau sont envoyées à un backend), deux options s'offrent à vous:
- Envisagez d'utiliser des entrées anti-rebond pour limiter le nombre de fois où un rappel d'événement s'exécute dans une période donnée.
- Utilisez
AbortController
pour annuler les requêtesfetch
sortantes afin que le thread principal ne soit pas encombré lors de la gestion des rappelsfetch
. Remarque: La propriétésignal
d'une instanceAbortController
peut également être utilisée pour annuler des événements.
L'augmentation du délai d'entrée dû aux interactions qui se chevauchent peut également entraîner des animations coûteuses. En particulier, les animations en JavaScript peuvent déclencher de nombreux appels requestAnimationFrame
, ce qui peut gêner les interactions de l'utilisateur. Pour contourner ce problème, utilisez des animations CSS dans la mesure du possible afin d'éviter la mise en file d'attente d'images d'animation potentiellement coûteuses. Toutefois, dans ce cas, assurez-vous d'éviter les animations non composées afin que les animations s'exécutent principalement sur les threads du GPU et du compositeur, et non sur le thread principal.
Conclusion
Même si les délais de saisie ne représentent pas la majorité du temps nécessaire à l'exécution de vos interactions, il est important de comprendre que chaque partie d'une interaction prend un temps que vous pouvez réduire. Si vous constatez que le délai de saisie est long, vous avez la possibilité de le réduire. Éviter les rappels récurrents de minuteur, répartir les longues tâches et être conscient des potentiels chevauchements d'interactions peut vous aider à réduire le délai d'entrée, ce qui accélère l'interactivité pour les utilisateurs de votre site Web.
Image principale tirée de Unsplash, par Erik Mclean.