GTAG优化ID

时间:2018-08-21 18:00:22

标签: google-analytics analytics.js gtag.js google-optimize

以下gtag.js的Google Optimize集成的analytics.js等效项是什么:

ga('set', 'expId', '$experimentId');     // The id of the experiment the user has been exposed to.
ga('set', 'expVar', '$chosenVariation'); // The index of the variation shown to the user.

我在Google网站上找不到任何记录。

我看过的一些地方: https://developers.google.com/analytics/devguides/collection/gtagjs/migration https://developers.google.com/analytics/devguides/collection/analyticsjs/experiments

更新-2018年8月23日-使用@AnkDasCo的回复

此外,我的Optimize实验配置为SERVER_SIDE,这意味着我不希望Optimize将实验和变体分配给该站点。相反,这是我想从一开始就控制的事情。我在页面中注入了以下内容:

window.dataLayer = window.dataLayer || [];
function gtag(){dataLayer.push(arguments);}
gtag('js', new Date());
gtag('set', {'expId': 'xxxxxxxxxxxxxxxxxxxxxx'});
gtag('set', {'expVar':'1'});  // set to variant id 1
gtag('config', 'UA-xxxxxxxx-y', { 'optimize_id': 'GTM-xxxxxxx'});

但是,变量分配仍由Optimize(而不是上面的脚本)控制。在上面的示例中,我要求将其设置为变体ID 1,但这没有发生。

即使在单个语句中设置实验/变体,因为这也不起作用:

gtag('set', {'exp': 'xxxxxxxxxxxxxxxxxxxxxx.1'});

任何人都以为我可能会想念的东西。任何帮助将不胜感激。

2 个答案:

答案 0 :(得分:3)

您仍然可以$scope.$broadcast()保留在页面上gtag调用之间的值。

set

答案 1 :(得分:0)

analytics.js方法有效:

<script>
  (function(i,s,o,g,r,a,m){i['GoogleAnalyticsObject']=r;i[r]=i[r]||function(){
  (i[r].q=i[r].q||[]).push(arguments)},i[r].l=1*new Date();a=s.createElement(o),
  m=s.getElementsByTagName(o)[0];a.async=1;a.src=g;m.parentNode.insertBefore(a,m)
  })(window,document,'script','https://www.google-analytics.com/analytics.js','ga');

  ga('create', 'UA-xxxxxxxx-y', 'auto');
  ga('set', 'exp', 'xxxxxxxxxxxxxxxxx.1');
  ga('require', 'GTM-xxxxxx');
  ga('send', 'pageview');
</script>

请注意,由于将实验设置为SERVER_SIDE,因此设置实验和变体的效果需要由服务器处理,而Optimize在其中不起作用。如果您在服务器端,则您可以自己完成所有工作-您可以为“ A页”创建实验,然后从“ B页”发送实验匹配数据,一切仍然可以正常进行。