跳转到主要内容
本指南介绍了使用 OneSignal HTML 编辑器 创建的 HTML 应用内消息的 JavaScript API 如果您正在寻找设置触发器、处理应用内点击事件或管理应用内消息生命周期的 SDK 方法,请参阅 移动端 SDK 参考

要求

1. 使用 data-onesignal-unique-label 进行点击跟踪

所有可点击元素都必须具有带有 唯一 值的 data-onesignal-unique-label 属性。这使 OneSignal 能够:
  • 跟踪点击分析
  • 正确触发关联的操作
HTML
<button id="tag-user-button" data-onesignal-unique-label="my-tag-user-button">
  Tag User
</button>
如果两个元素共享相同的 data-onesignal-unique-label,点击可能会被错误记录或操作可能不会触发。

2. 附加事件监听器

您必须显式附加 JavaScript 事件监听器来触发 OneSignal 应用内操作。
JavaScript
document.getElementById("tag-user-button")
  .addEventListener("click", function(e) {
    OneSignalIamApi.tagUser(e, { fiz: "baz" });
  });
示例:
HTML
<button id="tag-user-button" data-onesignal-unique-label="my-tag-user-button">
  Tag User
</button>
<script>
  document.getElementById("tag-user-button").addEventListener("click", function(e) {
    OneSignalIamApi.tagUser(e, { fiz: "baz" });
  });
</script>

可用函数

块编辑器 中的所有 点击操作 也适用于 HTML 应用内消息。

推送权限提示

显示原生推送通知权限提示。点击事件会自动跟踪。 请参阅 推送权限提示
HTML
<button id="push-prompt-button" data-onesignal-unique-label="push-permission">
  Enable Push
</button>
<script>
  document.getElementById("push-prompt-button").addEventListener("click", function(e) {
    OneSignalIamApi.triggerPushPrompt(e);
  });
</script>

位置权限提示

显示原生位置权限提示。点击事件会自动跟踪。 请参阅 位置权限提示
HTML
<button id="location-prompt-button" data-onesignal-unique-label="location-permission">
  Enable Location
</button>
<script>
  document.getElementById("location-prompt-button").addEventListener("click", function(e) {
    OneSignalIamApi.triggerLocationPrompt(e);
  });
</script>

关闭应用内消息

关闭当前应用内消息。点击事件会自动跟踪。
html
<button id="close-button" data-onesignal-unique-label="close-message">
  Close
</button>
<script>
  document.getElementById("close-button").addEventListener("click", function(e) {
    OneSignalIamApi.close(e);
  });
</script>

标记用户

设置 标签。点击事件会自动跟踪。
HTML
<button id="tag-user-button" data-onesignal-unique-label="tag-user">
  Tag User
</button>
<script>
  document.getElementById("tag-user-button").addEventListener("click", function(e) {
    OneSignalIamApi.tagUser(e, { fiz: "baz" });
  });
</script>

打开 URL

在设备浏览器中打开 URL 并关闭应用内消息。点击事件会自动跟踪。 支持 深度链接
HTML
<button id="open-url-button" data-onesignal-unique-label="open-website">
  Visit Site
</button>
<script>
  document.getElementById("open-url-button").addEventListener("click", function(e) {
    OneSignalIamApi.openUrl(e, "https://example.com");
  });
</script>

点击名称

分配一个可以在 应用内消息点击监听器 中读取的点击名称。点击事件会自动跟踪。 支持 深度链接
HTML
<button id="click-name-button" data-onesignal-unique-label="named-click">
  Click Me
</button>
<script>
  document.getElementById("click-name-button").addEventListener("click", function(e) {
    OneSignalIamApi.addClickName(e, "test_click_name");
  });
</script>

跟踪点击

在您不使用其他可点击 API 方法时跟踪点击事件。
html
<button id="track-click-button" data-onesignal-unique-label="custom-track">
  Track Click
</button>
<script>
  document.getElementById("track-click-button").addEventListener("click", function(e) {
    OneSignalIamApi.trackClick(e);
  });
</script>

发送结果

跟踪 自定义结果。点击事件会自动跟踪。
html
<button id="send-outcome-button" data-onesignal-unique-label="bonus-claim">
  Claim Bonus
</button>
<script>
  document.getElementById("send-outcome-button").addEventListener("click", function(e) {
    OneSignalIamApi.sendOutcome(e, "bonus_claimed");
  });
</script>

个性化 HTML 应用内消息

您可以在 HTML 应用内消息中使用标签替换,就像在块编辑器中一样。
标签替换 不适用于 <script> 标签内。
标签替换适用于:
  • 内联文本(<h1><p><li> 等)
  • <style> 规则:
    CSS
    body { background-color: "{{ favorite_color | default: '#fff' }}"; }
    
  • 带 URL 的属性:
    • href
    • src
    • <form action>
    • <object data>

openUrl()addClickName() 中使用标签

由于 <script> 标签不支持替换,请使用以下方法之一: 1. 使用 liquidPlayerTags 访问所有标签 此全局对象在 DOMContentLoaded 后可用。
HTML
<div class="my-tags">--test checking all tags--</div>
<button id="open-url-button" data-onesignal-unique-label="promo-link">
  Personalized Offer
</button>
<script>
  document.addEventListener("DOMContentLoaded", function() {
    if (liquidPlayerTags) {
      // liquidPlayerTags becomes available afterthe DOMContentLoaded event confirm
      // by checking that the div with --replace with all tags-- is replaced with JSON
      document.querySelector(".my-tags").innerHTML = JSON.stringify(liquidPlayerTags);
    }
  });
  document.addEventListener("DOMContentLoaded", function() {
    document.getElementById("open-url-button").addEventListener("click", function(e) {
      OneSignalIamApi.openUrl(e, "https://shop.com?coupon=" + liquidPlayerTags["coupon"]);
    });
  });
</script>
2. 在 href 属性中存储标签
HTML
<a
  id="open-url-button"
  href="app://deeplink?code={{ coupon | default: '10OFF' }}"
  data-onesignal-unique-label="promo-link"
>
  Redeem Offer
</a>
<script>
  document.getElementById("open-url-button").addEventListener("click", function(e) {
    e.preventDefault();
    OneSignalIamApi.openUrl(e, e.currentTarget.href);
  });
</script>

后续步骤


I