Messages in-app HTML personnalisés
Bien que nos messages in-app standard puissent être personnalisés de nombreuses façons, vous pouvez obtenir un contrôle encore plus grand sur l’apparence de vos campagnes en utilisant des messages conçus et construits avec HTML, CSS et JavaScript. Avec une composition simple, vous pouvez débloquer des fonctionnalités et un branding personnalisés pour répondre à tous vos besoins.
Ce type de message est disponible dans l’éditeur traditionnel.
Comment ça fonctionne
Les messages in-app HTML permettent un contrôle accru sur l’apparence d’un message, notamment les éléments suivants :
- Polices et styles personnalisés
- Vidéos
- Images multiples
- Comportements au clic
- Composants interactifs
- Animations personnalisées
Les messages HTML personnalisés peuvent utiliser les méthodes du pont JavaScript pour enregistrer des événements, définir des attributs personnalisés, fermer le message, et bien plus encore ! Consultez notre dépôt GitHub qui contient des instructions détaillées sur la façon d’utiliser et de personnaliser les messages in-app HTML selon vos besoins, ainsi qu’un ensemble de modèles de messages in-app HTML5 pour vous aider à démarrer.

Pour activer les messages in-app HTML via le SDK Web, vous devez fournir l’option d’initialisation allowUserSuppliedJavascript à Braze : par exemple, braze.initialize('YOUR-API_KEY', {allowUserSuppliedJavascript: true}). Ceci est pour des raisons de sécurité, car les messages in-app HTML peuvent exécuter du JavaScript, nous exigeons donc qu’un responsable du site les active.
Pont JavaScript
Custom HTML in-app messages and Banners support a JavaScript “bridge” to interface with the Braze SDK, allowing you to trigger custom Braze actions when users click on elements with links or otherwise engage with your content. These methods exist with the global brazeBridge or appboyBridge variable.

Braze recommends that you use the global brazeBridge variable. The global appboyBridge variable is deprecated but will continue to function for existing users. If you are using appboyBridge, we suggest you migrate to brazeBridge.
appboyBridge was deprecated in the following SDK versions:
For example, to log a custom attribute and custom event, then close the message, you could use the following JavaScript within your custom HTML:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
<button id="button">Set Favorite Color</button>
<script>
// Wait for the `brazeBridge` ready event, "ab.BridgeReady"
window.addEventListener("ab.BridgeReady", function(){
// Event handler when the button is clicked
document.querySelector("#button").onclick = function(){
// Track Button 1 clicks for analytics
// Note: This requires Android SDK v8.0.0, Web SDK v2.5.0, Swift SDK v5.4.0, and iOS SDK v3.23.0
brazeBridge.logClick("0");
// Set the user's custom attribute
brazeBridge.getUser().setCustomUserAttribute("favorite color", "blue");
// Track a custom event
brazeBridge.logCustomEvent("completed survey");
// Send the enqueued data to Braze
brazeBridge.requestImmediateDataFlush();
// Close the message
brazeBridge.closeMessage();
};
}, false);
</script>
JavaScript Bridge methods
The following JavaScript methods are supported within custom HTML for in-app messages and Banners:

You cannot reference Liquid to insert customAttributes into JavaScript Bridge methods.
| Nom de la méthode | Description |
|---|---|
brazeBridge.closeMessage() |
Ferme le message actuel. Le comportement diffère selon le canal : Messages in-app : ferme uniquement l’interface. Aucun rejet n’est enregistré et aucune suppression côté serveur n’a lieu. Bannières : équivaut à appeler logBannerDismissal. Cela enregistre un rejet de bannière, supprime la bannière de l’interface et empêche son affichage pour l’utilisateur. Cela redéclenche également tous les abonnés subscribeToBannersUpdates actifs. N’appelez pas cette méthode si le message est déjà en cours de fermeture ou s’il se fermera automatiquement en raison du traitement d’un lien profond. |
window.addEventListener("ab.BridgeReady", function(){...}, false) |
Méthode de rappel déclenchée une fois que le chargement de brazeBridge est terminé. Tout le code JavaScript doit être exécuté dans cette fonction de rappel. |
brazeBridge.requestImmediateDataFlush() |
Envoie les données en file d’attente vers les serveurs Braze. Documentation JS |
brazeBridge.logClick(button_id_string) |
Enregistre un clic de bouton pour un ID de bouton donné. Lorsque button_id_string est laissé vide, un clic sur le corps du message est enregistré à la place. Le paramètre button_id_string peut être transmis comme button_id dans les événements de clics des messages in-app via Currents. Cette méthode a été introduite dans le SDK Android v8.0.0, le SDK Web v2.5.0 et le SDK iOS v3.23.0. Le paramètre button_id_string n’accepte que les caractères alphanumériques, les espaces, les tirets et les traits de soulignement. L’ajout d’un caractère accentué (par exemple ö, â, ê) interrompt le suivi des clics sur le bouton, ce qui fait que la chaîne de caractères du bouton n’apparaît pas dans la section d’analyse de la campagne et que les clics ne sont pas comptabilisés. |
brazeBridge.logCustomEvent(eventName,eventProperties) |
Enregistre un événement personnalisé. Documentation JS |
brazeBridge.logPurchase(productId, price, currencyCode, quantity, purchaseProperties) |
Enregistre un achat. Documentation JS |
brazeBridge.getUser().addAlias(alias, label) |
Ajoute un alias à un utilisateur. Introduit dans le SDK Web v2.7.0, le SDK Android v8.1.0 et le SDK iOS v3.26.0. Documentation JS |
brazeBridge.getUser().addToCustomAttributeArray(key, value) |
Ajoute une valeur à un tableau d’attributs personnalisés. Documentation JS |
brazeBridge.getUser().addToSubscriptionGroup(subscriptionGroupId) |
Ajoute un utilisateur à un groupe d’abonnement e-mail ou SMS. Documentation JS. Cette méthode a été introduite dans le SDK Android v15.0.0, le SDK Web v3.4.0 et le SDK iOS v4.3.3. |
brazeBridge.getUser().removeFromSubscriptionGroup(subscriptionGroupId) |
Supprime un utilisateur d’un groupe d’abonnement e-mail ou SMS. Documentation JS. Cette méthode a été introduite dans le SDK Android v15.0.0, le SDK Web v3.4.0 et le SDK iOS v4.3.3. |
brazeBridge.getUser().setFirstName(firstName) |
Définit le prénom d’un utilisateur. Documentation JS |
brazeBridge.getUser().setLastName(lastName) |
Définit le nom de famille d’un utilisateur. Documentation JS |
brazeBridge.getUser().setEmail(email) |
Définit l’adresse e-mail d’un utilisateur. Documentation JS |
brazeBridge.getUser().setGender(gender) |
Définit le sexe d’un utilisateur. Documentation JS |
brazeBridge.getUser().setDateOfBirth(year, month, day) |
Définit la date de naissance d’un utilisateur. Documentation JS |
brazeBridge.getUser().setCountry(country) |
Définit le pays d’un utilisateur. Documentation JS |
brazeBridge.getUser().setHomeCity(city) |
Définit la ville d’un utilisateur. Documentation JS |
brazeBridge.getUser().setEmailNotificationSubscriptionType(notificationSubscriptionType) |
Définit l’état d’abonnement aux notifications par e-mail. Documentation JS |
brazeBridge.getUser().setPushNotificationSubscriptionType(notificationSubscriptionType) |
Définit l’état d’abonnement aux notifications push. Documentation JS |
brazeBridge.getUser().setPhoneNumber(phoneNumber) |
Définit le numéro de téléphone d’un utilisateur. Documentation JS |
brazeBridge.getUser().setCustomUserAttribute(key, value, merge) |
Définit un attribut utilisateur personnalisé. Documentation JS |
brazeBridge.getUser().removeFromCustomAttributeArray(key, value) |
Supprime une valeur d’un tableau d’attributs personnalisés. Documentation JS |
brazeBridge.getUser().incrementCustomUserAttribute(key, incrementValue) |
Incrémente un attribut utilisateur personnalisé. Documentation JS |
brazeBridge.getUser().setLanguage(language) |
Définit la langue d’un utilisateur. Introduit dans le SDK Android v5.0.0 et le SDK Web v2.6.0. Documentation JS |
brazeBridge.getUser().setCustomLocationAttribute(key, latitude, longitude) |
Définit un attribut d’emplacement personnalisé. Introduit dans le SDK Android v5.0.0. Documentation JS |
brazeBridge.web.registerAppboyPushMessages(successCallback, deniedCallback) |
S’inscrire aux notifications push Web (Web uniquement). Cette méthode est sans effet lorsqu’elle est appelée dans un environnement non Web. Documentation JS |
brazeBridge.requestPushPermission(successCallback, deniedCallback) |
S’inscrire aux notifications push sur Web, iOS et Android. Remarque : les rappels de la méthode sont uniquement pris en charge sur le Web. Cette méthode a été introduite à partir du SDK Web v4.0.0, du SDK Android v21.0.0 et du SDK Swift v5.4.0. Documentation JS |
brazeBridge.changeUser(id, sdkAuthSignature?) |
Identifie l’utilisateur avec un ID unique. Documentation JS Cette méthode a été introduite dans le SDK Web v4.3.0. |
Button click tracking
Use the brazeBridge.logClick(button_id) method to track clicks in your custom HTML.

Banners: Only brazeBridge.logClick() (without arguments) is supported. Button IDs and custom button tracking are supported for in-app messages only.
For in-app messages, you can programmatically track “Button 1”, “Button 2”, and “Body Clicks” using brazeBridge.logClick('0'), brazeBridge.logClick('1'), or brazeBridge.logClick(), respectively.
| Clicks | Method | Supported |
|---|---|---|
| Body click | brazeBridge.logClick() |
In-app messages and Banners |
| Button 1 | brazeBridge.logClick('0') |
In-app messages only |
| Button 2 | brazeBridge.logClick('1') |
In-app messages only |
| Custom button tracking | brazeBridge.logClick('your custom name here') |
In-app messages only |
For in-app messages, you can track multiple button click events per impression. For example, to close a message and log a Button 2 click:
1
<a href="#" onclick="brazeBridge.logClick('1');brazeBridge.closeMessage()">✖</a>
You can also track new custom button names—up to 100 unique names per campaign. For example, brazeBridge.logClick('blue button') or brazeBridge.logClick('viewed carousel page 3').

When using JavaScript methods inside an onclick attribute, wrap string values in single quotes to avoid conflicts with the double-quoted HTML attribute.
Limitations (in-app messages only)
- You can have up to 100 unique button IDs per campaign.
- Button IDs can have up to 255 characters each.
- Button IDs can only include letters, numbers, spaces, dashes, and underscores.
Actions basées sur les liens
En plus du JavaScript personnalisé, les SDK Braze peuvent également envoyer des données d’analyse avec ces raccourcis URL pratiques. Notez que ces paramètres de requête et schémas d’URL sont tous sensibles à la casse.
Suivi des clics sur les boutons (obsolète)

L’utilisation de abButtonID n’est pas prise en charge dans les types de messages HTML avec prévisualisation. Pour plus d’informations, consultez notre guide de mise à niveau.
Pour enregistrer les clics sur les boutons dans les analyses des messages in-app, vous pouvez ajouter abButtonId comme paramètre de requête à tout lien profond, URL de redirection ou élément d’ancrage <a>. Utilisez ?abButtonId=0 pour enregistrer un clic sur « Bouton 1 », et ?abButtonId=1 pour enregistrer un clic sur « Bouton 2 ».
Comme pour les autres paramètres d’URL, le premier paramètre doit commencer par un point d’interrogation ?, tandis que les paramètres suivants doivent être séparés par une esperluette &.
Exemples d’URL
https://example.com/?abButtonId=0- Clic sur le Bouton 1https://example.com/?abButtonId=1- Clic sur le Bouton 2https://example.com/?utm_source=braze&abButtonId=0- Clic sur le Bouton 1 avec d’autres paramètres d’URL existantsmyApp://deep-link?page=home&abButtonId=1- Lien profond mobile avec clic sur le Bouton 2<a href="https://example.com/?abButtonId=1">- Élément d’ancrage<a>avec clic sur le Bouton 2

Les messages in-app ne prennent en charge que les clics sur le Bouton 1 et le Bouton 2. Les URL qui ne spécifient pas l’un de ces deux identifiants de bouton seront enregistrées comme des « clics sur le corps » génériques.
Ouvrir un lien dans une nouvelle fenêtre (mobile uniquement)
Pour ouvrir des liens en dehors de votre application dans une nouvelle fenêtre, définissez ?abExternalOpen=true. Le message sera fermé avant l’ouverture du lien.
Pour la création de liens profonds, Braze ouvrira votre URL quelle que soit la valeur de abExternalOpen.
Ouvrir en tant que lien profond (mobile uniquement)
Pour que Braze traite votre lien HTTP ou HTTPS comme un lien profond, définissez ?abDeepLink=true.
Lorsque ce paramètre de requête est absent ou défini sur false, Braze tentera d’ouvrir le lien web dans un navigateur web interne à l’intérieur de l’application hôte.
Fermer le message in-app
Pour fermer un message in-app, vous pouvez utiliser la méthode JavaScript brazeBridge.closeMessage().
Par exemple, <a onclick="brazeBridge.closeMessage()" href="#">Fermer</a> fermera le message in-app.
Téléchargement HTML avec prévisualisation
Lors de la création de messages in-app HTML personnalisés, vous pouvez prévisualiser votre contenu interactif directement dans Braze.
Le panneau de prévisualisation du message de l’éditeur affiche un aperçu réaliste qui rend le JavaScript inclus dans votre message. Vous pouvez prévisualiser et interagir avec vos messages personnalisés depuis le panneau de prévisualisation en cliquant à travers la pagination, en soumettant des formulaires ou des sondages, en regardant des animations JavaScript, et bien plus encore !


Les méthodes JavaScript brazeBridge que vous utilisez dans votre HTML ne mettront pas à jour les profils utilisateur lors de la prévisualisation dans le tableau de bord.
Exigences du SDK
Pour utiliser la prévisualisation HTML pour les messages in-app, vous devez effectuer la mise à niveau vers les versions minimales suivantes du SDK Braze :

Étant donné que ce type de message ne peut être reçu que par certaines versions ultérieures du SDK, les utilisateurs disposant de versions du SDK non prises en charge ne recevront pas le message. Envisagez d’adopter ce type de message une fois qu’une partie significative de votre base d’utilisateurs est accessible, ou ciblez uniquement les utilisateurs dont la version de l’application est ultérieure aux exigences. En savoir plus sur le filtrage par version la plus récente de l’application.
Créer une campagne
Les utilisateurs de votre application mobile doivent effectuer la mise à niveau vers les versions du SDK prises en charge pour recevoir un message in-app Code personnalisé. Nous vous recommandons d’encourager les utilisateurs à mettre à niveau leurs applications mobiles avant de lancer des campagnes qui dépendent de versions plus récentes du SDK Braze.
Fichiers de ressources
Lors de la création de messages in-app avec code personnalisé et téléchargement HTML, vous pouvez télécharger les ressources de la campagne dans la bibliothèque multimédia pour les référencer dans votre message.
Les types de fichiers suivants sont pris en charge pour le téléchargement :
| Type de fichier | Extension de fichier |
|---|---|
| Fichiers de polices | .ttf, .woff, .otf, .woff2 |
| Images SVG | .svg |
| Fichiers JavaScript | .js |
| Fichiers CSS | .css |
Braze recommande de télécharger les ressources dans la bibliothèque multimédia pour deux raisons :
- Les ressources ajoutées à une campagne via la bibliothèque multimédia permettent à vos messages d’être affichés même lorsque l’utilisateur est hors ligne ou dispose d’une mauvaise connexion internet.
- Les ressources téléchargées sur Braze peuvent être réutilisées dans plusieurs campagnes.
Ajouter des fichiers de ressources
Vous pouvez ajouter des ressources nouvelles ou existantes à votre campagne.
Pour ajouter de nouvelles ressources à votre campagne, utilisez la section de glisser-déposer pour télécharger un fichier. Les ressources ajoutées dans cette section seront également automatiquement ajoutées à la bibliothèque multimédia. Pour ajouter des ressources que vous avez déjà téléchargées dans la bibliothèque multimédia, sélectionnez Add from Media Library.
Une fois vos ressources ajoutées, elles apparaîtront dans la section Assets for this campaign.
Si le nom de fichier d’une ressource correspond à celui d’une ressource HTML locale, elle est remplacée automatiquement (par exemple, cat.png est téléchargé et <img src="cat.png" /> existe).
Sinon, survolez une ressource de la liste et sélectionnez Copy pour copier l’URL du fichier dans votre presse-papiers. Collez ensuite l’URL de la ressource copiée dans votre HTML comme vous le feriez normalement pour référencer une ressource distante.
Éditeur HTML
Les modifications que vous apportez dans le HTML sont automatiquement rendues dans le panneau de prévisualisation au fur et à mesure que vous tapez. Les méthodes JavaScript brazeBridge que vous utilisez dans votre HTML ne mettront pas à jour les profils utilisateur lors de la prévisualisation dans le tableau de bord.

Vous pouvez sélectionner Search dans l’éditeur HTML pour effectuer une recherche dans votre code !
Suivi des boutons
Vous pouvez suivre les performances au sein de votre message in-app avec code personnalisé en utilisant la méthode JavaScript brazeBridge.logClick(button_id). Cela vous permet de suivre programmatiquement « Bouton 1 », « Bouton 2 » et « Clics sur le corps » en utilisant respectivement brazeBridge.logClick('0'), brazeBridge.logClick('1') ou brazeBridge.logClick().
| Clics | Méthode |
|---|---|
| Bouton 1 | brazeBridge.logClick('0') |
| Bouton 2 | brazeBridge.logClick('1') |
| Clic sur le corps | brazeBridge.logClick() |
| Suivi de bouton personnalisé | brazeBridge.logClick('your custom name here') |

Cette méthode de suivi des boutons remplace les méthodes de suivi automatique des clics précédentes (telles que ?abButtonId=0), qui ont été supprimées.
Modifications rétro-incompatibles
- La modification incompatible la plus notable avec ce nouveau type de message concerne les exigences du SDK. Les utilisateurs dont le SDK de l’application ne répond pas aux exigences minimales de version du SDK ne verront pas le message.
- Le lien profond
braze://close, qui était auparavant pris en charge sur les applications mobiles, a été supprimé au profit de la méthode JavaScriptbrazeBridge.closeMessage(). Cela permet des messages HTML multiplateformes, car le web ne prend pas en charge les liens profonds. -
Le suivi automatique des clics, qui utilisait
?abButtonId=0pour les identifiants de bouton, et le suivi des « clics sur le corps » sur les boutons de fermeture ont été supprimés. Les exemples de code suivants montrent comment modifier votre HTML pour utiliser nos nouvelles méthodes JavaScript de suivi des clics :Avant Après <a href="braze://close">Close Button</a><a href="#" onclick="brazeBridge.logClick();brazeBridge.closeMessage()">Close Button</a><a href="braze://close?abButtonId=0">Close Button</a><a href="#" onclick="brazeBridge.logClick('0');brazeBridge.closeMessage()">Close Button</a><a href="app://deeplink?abButtonId=0">Track button 1</a><a href="app://deeplink" onclick="brazeBridge.logClick('0')">Track button 1</a><script>
location.href = "braze://close?abButtonId=1"
</script><script>
window.addEventListener("ab.BridgeReady", function(){
brazeBridge.logClick("1");
brazeBridge.closeMessage();
});
</script>