4

我在将 Google Optimize 与我们的 React 应用程序一起使用时遇到了问题(例如https://quality.livechatinc.com/1520)。应该运行一个简单的 A/B 测试(文本替换)。

测试的预览以某种方式起作用(gaexp设置了cookie,并且在预览模式下,只有在重新加载页面**之后,才会触发变体)。

发布测试时,未设置 cookie,因此测试无法完全运行。

下面是 GA/GTM/Optimize 的实现:

//Page-hiding snippet.
<style>.async-hide { opacity: 0 !important} </style>
<script>(function(a,s,y,n,c,h,i,d,e){s.className+=' '+y;h.start=1*new Date;
h.end=i=function(){s.className=s.className.replace(RegExp(' ?'+y),'')};
(a[n]=a[n]||[]).hide=h;setTimeout(function(){i();h.end=null},c);h.timeout=c;
})(window,document.documentElement,'async-hide','dataLayer',4000,
{'GTM-XXXXXX':true});</script> //instead of X we have our Optimize container ID

//Optimize code without ga(`send`), as we use GTM to send pageviews
<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-XXXXXX-XX', 'auto'); //instead of X we have our GA tracking code
  ga('require', 'GTM-XXXXXXX'); //instead of X we have our Optimize container ID
</script>

//GTM code
<!-- Google Tag Manager -->
<script>(function(w,d,s,l,i){w[l]=w[l]||[];w[l].push({'gtm.start':
    new Date().getTime(),event:'gtm.js'});var f=d.getElementsByTagName(s)[0],
    j=d.createElement(s),dl=l!='dataLayer'?'&l='+l:'';j.async=true;j.src=
    'https://www.googletagmanager.com/gtm.js?id='+i+dl;f.parentNode.insertBefore(j,f);
})(window,document,'script','dataLayer','GTM-XXXXXXX');</script>
<!-- End Google Tag Manager -->

代码放置在<head>应用程序中,就在<meta>和之后<links>

我尝试使用自定义 dataLayer 事件触发优化测试,如优化文档建议(https://support.google.com/360suite/optimize/answer/7008840?hl=en),但它没有解决问题.

我尝试清除和禁用缓存/cookies,并检查测试是否在各种浏览器、隐身模式、计算机中有效——没有任何效果。

你有在 React 应用中使用 Google Optimize 的经验吗?任何想法如何解决这个问题?

提前致谢!

米哈乌


** 这可能暗示发生了什么,但我不知道为什么会这样。

4

1 回答 1

4

即使认为这是一个有点老的问题,你可能已经解决了,我也有类似的问题,很难找到正确的解决方案。因此,对于仍在为此苦苦挣扎的任何人。

因此,您所做的一切都是正确的,但是我认为您没有在 DOM 更改时触发 dataLayer 事件,因此您需要添加观察者函数来执行此操作。

这是代码示例,应该在 之前的某个位置添加,但在所有脚本之后。(也可以在 index.html 中)

<!-- This will send an activate event to Optimize, anytime that there is a change in the DOM --> 
<script> 
    window.dataLayer = window.dataLayer || []; 
    if (MutationObserver) { 
      new MutationObserver(function(){ 
        dataLayer.push({'event': 'optimize.activate'}); 
      }).observe(document.body, {subtree: true, attributes: true, characterData: true}); 
    } 
  </script> 

另外,不要忘记在优化中设置以激活自定义事件而不是页面加载的实验(如此处所述https://support.google.com/360suite/optimize/answer/7008840?hl=en

于 2018-03-26T06:47:13.533 回答