Configuration du datalayer
Un Commanders Act Data Layer est un objet JavaScript qui contient les métadonnées d'un site web en tant que propriétés pour les rendre disponibles aux tag. Dans la plateforme, ce Data Layer est nommé "External Variables" pour le distinguer des "Internal Variables" scriptées qui sont générées au sein du Container JavaScript.
Installation
Pour installer un Commanders Act Data Layer, il est nécessaire d'implémenter un objet JavaScript global tc_vars
qui contient les méta-données de la page en tant que propriétés directes. Les propriétés requises du Data Layer sont définies lors du processus de configuration de Commanders Act, mais vous pouvez trouver une liste de propriétés courantes sur cette page.
Réutiliser un Data Layer existant
Dans le cas où un site web dispose déjà d'un Data Layer installé, il est possible de le transformer en Commanders Act Data Layer. Veuillez contacter un consultant Commanders Act pour implémenter la transformation.
L'approche pour remplir le Data Layer avec des propriétés dépend du framework technologique utilisé sur le site web et peut aller du web scraping JavaScript au templating en passant par le hardcoding.
<script>
window.tc_vars = {
env_template : "homepage",
env_work : "prod",
page_name : "Homepage",
page_keywords : ["homepage", "home", "entrypage", "index"],
product_name : "",
(…)
};
window.tc_vars.user_name = "myuser";
</script>
<script src="{{ container_URL }}"></script>
Le Data Layer doit être rempli d'informations avant que le fichier du Web Container ne soit chargé — sinon les informations pourraient ne pas être disponibles au moment où le Container JavaScript s'exécute.
Conditions de course
Les conditions de course entre les propriétés du Data Layer et le Container JavaScript peuvent être difficiles à identifier et à déboguer par les utilisateurs de Commanders Act. Il est donc important de les éviter lors de l'installation !
Dans le cas où plusieurs Container sont utilisés sur la même page, il est possible de remplir le Data Layer en plusieurs étapes. Les informations globales comme le type de page doivent être rendues disponibles avant le chargement du premier Container. Les informations qui ne sont pertinentes que pour un certain Container (par ex. les informations produit) peuvent être ajoutées avant le Container concerné.
L'exemple suivant décrit comment un Data Layer peut être installé dans le cas où à la fois un <head>
et un <body>
Container sont utilisés sur un site web.
<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<script>
window.tc_vars = Object.assign({}, window.tc_vars, {
env_template : "homepage",
env_work : "prod"
});
</script>
<script src="{{ head_container_URL }}"></script>
(…)
<head>
<body>
(…)
<script>
window.tc_vars = Object.assign({}, window.tc_vars, {
page_name : "Homepage",
page_keywords : ["homepage", "home", "entrypage", "index"]
});
</script>
<script src="{{ body_container_URL }}"></script>
</body>
</html>
Convention de nommage du Data Layer
Comme illustré dans l'exemple ci‑dessus, les propriétés du Data Layer sont généralement regroupées avec une notation préfixe. Par ex. env_
est utilisé pour regrouper les informations d'environnement et user_
est utilisé pour regrouper les informations utilisateur.
Dans le cas où une propriété n'est pas pertinente pour une certaine page (par ex. product_name
sur la page de politique de confidentialité), il est recommandé de la remplir avec une valeur vide (par ex. ""
, 0
, []
ou {}
).
Test
Via la console JavaScript
Il est possible d'examiner le Data Layer dans la console JavaScript en journalisant tc_vars
.
Vous trouverez ci‑dessous un exemple de sortie d'un tc_vars
Data Layer dans la console JavaScript.
{
env_template : "homepage",
env_work : "prod",
page_name : "Homepage",
page_keywords : ["homepage", "home", "entrypage", "index"],
product_name : "",
(…)
}
Via le Tag Quality Assurance
Le template de tag Commanders Act - Data Layer QA dans la bibliothèque de tag Commanders Act affiche automatiquement les informations du Data Layer dans la console JavaScript sur chaque page. Cette approche a l'avantage d'enregistrer un instantané du Data Layer au moment exact où le Container JavaScript a été exécuté. Cela permet d'identifier les conditions de course entre les propriétés du Data Layer et le Container JavaScript afin de s'assurer que toutes les propriétés nécessaires sont disponibles à temps.
Mis à jour
Ce contenu vous a-t-il été utile ?