Optimisation des performances

Stratégies pour améliorer les performances sur site de TagCommander.

La performance onsite d'un site web est l'un des KPI les plus importants pour le SEO. Par conséquent, de plus en plus d'entreprises s'intéressent à l'optimisation de la performance onsite via TagCommander. Ce post rassemble des sujets pour rendre TagCommander lui-même plus performant.

Réduire la taille du fichier TagCommander

Supprimer les propriétés Data Layer inutilisées

Chaque propriété Data Layer configurée dans les options de l'interface crée un peu de code JavaScript dans le Container pour initialiser la variable au cas où elle n'était pas présente dans le Data Layer onsite tc_vars. Supprimer les variables inutilisées/anciennes rendra donc le fichier Container un peu plus petit (et comme effet secondaire améliorera également la transparence de la configuration du Container).

Supprimer les variables internes inutilisées

Chaque variable interne configurée dans les options de l'interface est un snippet JavaScript, donc supprimer les variables internes permet de réduire la taille d'un fichier Container. Cela peut être fait en supprimant les variables internes inutilisées et aussi en spécifiant quelles variables sont utilisées dans quel Container. Ceci est particulièrement important pour les clients avec un <head> et <body> Container et les clients qui ont plusieurs Containers pour différents sites web.

Ne vous répétez pas

Parfois la même fonctionnalité d'un Tag est dupliquée dans plusieurs Tags. Dans ces cas, il est possible d'économiser une bonne quantité de code JavaScript et de taille de fichier Container en refactorisant la fonctionnalité commune dans une variable interne ou dans un Tag commun. Par exemple, de nombreux Tags se composent de deux parties. Une partie charge une bibliothèque JavaScript externe du fournisseur et une partie envoie l'événement réel au fournisseur. Par défaut, le code qui charge la bibliothèque JavaScript est souvent dupliqué dans chaque événement. Donc extraire la première partie dans un base Tag permet de supprimer le JavaScript dupliqué.

Diviser les gros fichiers Container

Beaucoup de Tags sont déployés sur chaque page d'un site web même s'ils ne sont pas déclenchés. Par exemple, de nombreux fournisseurs ont des Tags séparés pour collecter des informations et un seul Tag qui est joué sur la page de confirmation. Par conséquent, il peut être judicieux de diviser le Container en deux parties — une pour les pages catalogue et une pour les pages tunnel. Ainsi, les deux Containers ont une taille plus petite car ils n'incluent que les Tags pertinents pour leur partie du site.

Assurez-vous également d'implémenter des Tags dans <head> Container uniquement si nécessaire car ces Tags ont généralement un impact plus important sur la performance onpage que les Tags dans `<body>` Container.

Implémenter une configuration TagCommander hybride

Une configuration hybride permet de déplacer l'impact sur la performance onsite vers l'infrastructure Server-Side TagCommander.

Rendre TagCommander asynchrone

Charger le Container de façon asynchrone

De nombreux crawlers de vitesse de page onsite mesurent le temps jusqu'à l'événement navigateur événement onload. Donc si l'équipe IT charge le Container TagCommander de façon asynchrone sur l'événement événement onload il est possible de rendre le fichier TagCommander invisible pour certaines métriques de vitesse de page. Ceci est généralement possible uniquement pour <body> Containers car <head> les Containers doivent être exécutés de manière synchrone pour les Tags d'A/B testing et de personnalisation qui ont un impact sur le contenu visuel du site.

Charger les Tags de manière asynchrone

JavaScript est pour la plupart un langage mono-thread, cela signifie que le JavaScript de longue durée (comme un long processus en boucle) peut bloquer d'autres parties du JavaScript qui devraient être exécutées immédiatement. Il est possible de mettre du JavaScript long à exécution sur un exécuter plus tard avec une pile de priorité plus basse en l'encapsulant à l'intérieur d'un setTimeout avec un délai de 0 ms.

Ceci doit être testé avec chaque Tag individuel car certains pourraient ne pas être compatibles avec cette approche.

Mis à jour

Ce contenu vous a-t-il été utile ?