Champs pris en charge par type de message
- E-mail
- Push
- SMS
- Messages in-app
- Live Activities
- Objet, Répondre à et Pré-en-tête
- Corps du message
- Substitution d’image dans les blocs HTML. Exemple :
<img src="{{image_url}}"/> - Actions de bloc de bouton comme les URL, Mail to et d’autres champs.
Syntaxe de base
Liquid utilise deux structures de syntaxe principales :- Balises de sortie :
{{ ... }}- Affiche les données d’une variable ou d’un objet. - Balises logiques :
{% ... %}- Exécute des instructions conditionnelles ou des boucles.
Sources de données
| Source | Exemple | Description |
|---|---|---|
| Tag | {{ first_name }} | SDK OneSignal ou API (tags) |
| Propriété | {{ subscription.email }} | Géré par le système (e-mail, external_id, langue, etc.) |
| Nom du Journey | {{ journey.name }} | Géré par le système |
| Données personnalisées | {{ message.custom_data.key }} | custom_data passé dans l’API Create Message |
| Data Feeds | {{ data_feed.cart.size }} | Les Data Feeds vous permettent d’extraire des données en temps réel de vos API directement dans les messages au moment de l’envoi. |
| Événements personnalisés | {{ journey.last_event.name }} | Défini via les Journeys déclenchés par événement, les nœuds Wait Until |
Conditionnels
Opérateurs
==,!=,>,<,>=,<=and,orcontains(chaîne ou tableau)
Les opérations s’exécutent de droite à gauche. Les parenthèses ne sont pas prises en charge.
liquid
if, elsif, else
liquid
unless
liquid
Filtres
Appliquez des filtres en utilisant{{ variable | filter }} pour ajuster la façon dont les données sont affichées.
default
Attribue une valeur par défaut si la propriété est vide ou n’existe pas.
liquid
date
Le filtre date convertit un timestamp en un autre format de date. Le format de cette syntaxe est le même que strftime. L’entrée utilise le même format que la méthode Time.parse de Ruby.
Définissez les dates comme un timestamp unix en secondes avec des tags. Cela permet d’utiliser à la fois la personnalisation avec la syntaxe Liquid et la segmentation avec les Opérateurs de temps. Par exemple, un tag pourrait ressembler à : bill_due : 1687968776
liquid
Result
liquid
Result
liquid
Result
now (ou today) avec le filtre date.
liquid
Result
L’heure actuelle sera affichée dans le message en fonction du moment où le message est
envoyé au destinataire. Si vous testez le message, vous verrez l’heure
actuelle comme étant celle de l’envoi du message de test.
capitalize
Ce filtre met en majuscule le premier caractère d’une chaîne et convertit les caractères restants en minuscules.
liquid
Result
round
Ce filtre arrondit un nombre à l’entier le plus proche ou, si un nombre est passé en argument, à ce nombre de décimales.
liquid
Result
pluralize
Ce filtre retourne la forme singulière ou plurielle d’une chaîne en fonction d’un nombre donné. Le nombre doit être un nombre entier et peut être fourni sous forme de chaîne. Les formes singulière et plurielle d’une chaîne doivent être fournies.
liquid
Result
Itération
Boucles for
Exécute à plusieurs reprises un bloc de code. Pour une liste complète des attributs disponibles dans une boucle for, consultez l’objet boucle for.
liquid
Request Body
Results
limit & offset
Limite la boucle au nombre d’itérations spécifié. Par exemple, si vous voulez uniquement afficher 4 produits dans un message, vous pouvez utiliser Limits et Offsets pour spécifier le nombre de produits affichés.
Data
liquid
Result
Data
liquid
where
Crée un tableau incluant uniquement les objets avec une valeur de propriété donnée, ou toute valeur vraie par défaut.
Dans cet exemple, supposons que vous ayez une liste de produits et que vous souhaitiez afficher vos produits de cuisine séparément. En utilisant where, vous pouvez créer un tableau contenant uniquement les produits ayant un type de kitchen.
Data
liquid
Result
Manipulation de chaînes
Parfois, vous pouvez avoir des tags de données qui contiennent des chaînes dans un format qui n’est pas adapté pour être montré directement à vos utilisateurs, et vous devrez peut-être manipuler la chaîne pour ajuster le format. Ci-dessous se trouve un tableau de commandes de syntaxe Liquid qui peuvent être utilisées pour ajuster les chaînes. Vous pouvez utiliser la manipulation de chaînes à la fois sur les Tags et directement sur les chaînes écrites dans le message.| Commande | Description | Exemple | Sortie d’exemple |
|---|---|---|---|
replace | Remplace une sous-chaîne par une autre chaîne. | {{ 'hello world' | replace: 'world', 'there' }} | hello there |
capitalize | Met en majuscule la première lettre d’une chaîne. | {{ 'hello' | capitalize }} | Hello |
upcase | Convertit une chaîne en majuscules. | {{ 'hello' | upcase }} | HELLO |
downcase | Convertit une chaîne en minuscules. | {{ 'HELLO' | downcase }} | hello |
strip | Supprime les espaces blancs de début et de fin d’une chaîne. | {{ ' hello ' | strip }} | hello |
strip_html | Supprime toutes les balises HTML d’une chaîne. | {{ '<p>hello</p>' | strip_html }} | hello |
truncate | Raccourcit une chaîne à une longueur spécifiée, en ajoutant des points de suspension (…) si nécessaire. | {{ 'This is a long sentence' | truncate: 10 }} | This is a… |
truncatewords | Tronque une chaîne après un certain nombre de mots. | {{ 'This is a long sentence' | truncatewords: 2 }} | This is… |
replace_first | Remplace la première occurrence d’une sous-chaîne. | {{ 'hello world' | replace_first: 'world', 'there' }} | hello there |
prepend | Ajoute une chaîne au début d’une autre chaîne. | {{ 'world' | prepend: 'hello ' }} | hello world |
append | Ajoute une chaîne à la fin d’une autre chaîne. | {{ 'hello' | append: ' world' }} | hello world |
lstrip | Supprime les espaces blancs de début d’une chaîne. | {{ ' hello' | lstrip }} | hello |
rstrip | Supprime les espaces blancs de fin d’une chaîne. | {{ 'hello ' | rstrip }} | hello |
FAQ
Pourquoi la substitution ne fonctionne-t-elle pas ?
- Les messages in-app ne prennent pas en charge la substitution de propriétés.
- La substitution de tags ne fonctionne pas lors de l’utilisation de « Send Test Message ».
- Les clés de tags doivent être alphanumériques, ou utiliser _ et - (pas de points ni d’espaces).
- La substitution n’apparaît pas en mode aperçu — envoyez un vrai message pour tester.
Comment contrôler les espaces blancs et les sauts de ligne ?
Utilisez des tirets :{{- ... -}}, {%- ... -%} pour supprimer les espaces blancs environnants.
Consultez Contrôle des espaces blancs pour plus de détails.
Comment gérer le contenu généré par l’utilisateur ?
Enveloppez le texte généré par l’utilisateur dans{% raw %} et {% endraw %} pour empêcher l’analyse Liquid. Consultez syntaxe “raw”.
json