我在 React 应用程序(例如 https://quality.livechatinc.com/1520 )中使用 Google Optimize 时遇到了问题。应该运行一个简单的 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 的经验吗?任何想法如何解决这个问题?

提前致谢!

米哈乌



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

最佳答案

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

因此,您所做的一切都是正确的,但是我认为您没有在 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>

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

关于reactjs - Google Optimize 不适用于 React App(未设置 cookie),我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/45608687/

10-13 03:03