registerPreTrackCallback

registerPreTrackCallback 变量允许贵组织在编译图像请求 URL 后但在将其发送之前挂接 JavaScript 函数。您可以使用此变量将 AppMeasurement 收集的数据发送到合作伙伴或内部基础结构。

WARNING
请勿在registerPreTrackCallback变量内进行任何跟踪调用,如t()tl()。 在此变量中设置跟踪调用会导致图像请求无限循环!

每次调用 registerPreTrackCallback 变量时,您都会挂接该函数以在每次编译图像请求 URL 时运行。避免在同一页面加载过程中多次注册同一函数。

NOTE
registerPreTrackCallbackregisterPostTrackCallback 之间触发函数的时间和顺序无法得到保证。避免这两个函数之间存在依赖关系。

使用Web SDK扩展预跟踪回调

Web SDK无法在编译数据后但在将数据发送到Adobe之前挂接函数。 但是,您可以使用onBeforeEventSend注册一个函数,以便在发送数据之前执行。

  1. 使用您的AdobeID凭据登录到Adobe Experience Platform数据收集 UI。
  2. 单击所需的标记属性。
  3. 转到扩展选项卡,然后单击Adobe Experience Platform Web SDK下的​ 配置 ​按钮。
  4. 在数据收集下,单击​ 在事件发送回调代码之前编辑 ​按钮。
  5. 将所需的代码置于编辑器中。

手动实施Web SDK的预跟踪回调

Web SDK无法在编译数据后但在将数据发送到Adobe之前挂接函数。 但是,您可以使用onBeforeEventSend注册一个函数,以便在发送数据之前执行,类似于doPlugins。 有关详细信息,请参阅Web SDK文档中的全局修改事件

// Set the trackingCode XDM field to "New value"
alloy("configure", {
  "onBeforeEventSend": function(content) {
    content.xdm.marketing.trackingCode = "New value";
  }
})

使用Adobe Analytics扩展预跟踪回调

Adobe Analytics 扩展程序中没有专门的字段来使用此变量。 按照 AppMeasurement 语法使用自定义代码编辑器。

AppMeasurement和Analytics扩展自定义代码编辑器中的s.registerPreTrackCallback

s.registerPreTrackCallback 是一个函数,只接受函数作为参数。嵌套函数在发送图像请求之前运行。

s.registerPreTrackCallback(function(){/* Desired code */});

如果要在代码中使用图像请求 URL,请引用嵌套函数中的 requestUrl 字符串参数。您可以解析 requestUrl 变量以满足您的所需用途;调整此变量不会影响数据收集。

s.registerPreTrackCallback(function(requestUrl){
  console.log(requestUrl); // Outputs the full image request URL
});

您可以在 s.registerPreTrackCallback 函数中包含其他参数,这些参数可在嵌套函数中使用:

s.registerPreTrackCallback(function(requestUrl,a,b,c) {
    console.log(requestUrl); // Full image request URL
    console.log(a); // param1
    console.log(b); // param2
    console.log(c); // param3
}, "param1", "param2", "param3");
NOTE
设置页面变量或更改此函数中的 requestUrl 字符串​ 不会 ​影响在此函数调用后不久发送的图像请求。请改用 doPlugins() 变量。
recommendation-more-help
b4f6d761-4a8b-4322-b801-c85b9e3be690