javascript - Universal Analytics 中用于设置自定义维度的操作顺序

标签 javascript google-analytics google-analytics-api

我的网站正在迁移到 Universal Analytics,但我遇到了将自定义维度推送到 GA 的顺序问题。

以前,您可以在任何其他 _gaq 函数之前调用 _setCustomVar,GA 会很好地选择它。

即。

var _gaq = _gaq || [];
_gaq.push(['_setCustomVar', 5, "custom_key", "custom_value", 2]);

// DO OTHER STUFF 

var _gaq = _gaq || [];
_gaq.push(['_setAccount', 'UA-545323212-1']);
_gaq.push(['_setDomainName', 'mysite.com']);
_gaq.push(['_trackPageview']);

(function() {var ga = document.createElement('script'); ga.type = 'text/javascript'; ga.async = true;ga.src = ('https:' == document.location.protocol ? 'https://ssl' : 'http://www') + '.google-analytics.com/ga.js';var s = document.getElementsByTagName('script')[0]; s.parentNode.insertBefore(ga, s);})();

但是,在设置对象之前,我找不到使用通用分析调用此函数的方法:

ga('set', 'dimension2', 'CUSTOMDIMENSIONVALUE');

// DO OTHER STUFF

(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','//www.google-analytics.com/analytics.js','ga');
ga('create', 'UA-434323212-1', 'mysite.com');
ga('send', 'pageview');

由于 ga() 是一个函数,我如何在它存在之前调用集成?解码 GA Universal Analytics 脚本,看起来我可以将数据推送到对象中,但我发现在调用 ga('create') 函数之前什么都不会生效。

我知道简单的解决方案是将我的自定义维度调用向下移动到正确的顺序,但由于多种原因,这对我来说不是一个选择。

感谢任何帮助!

最佳答案

将 init block 和 'create' 调用移至页面顶部,位于您设置自定义代码的位置上方(如在 head 标记中),并保留 'send' 在页面底部调用,以便您的自定义代码位于它们之间,而无需实际移动自定义代码。

或者,将当前的主代码块保留在底部,并在 'create''send' 之间放置一个回调函数,然后将您的代码包装起来回调函数中的自定义代码。

关于javascript - Universal Analytics 中用于设置自定义维度的操作顺序,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/19389714/

相关文章:

c# - Ajax 到 WCF,无法将 Ajax 加载到对象中

javascript - 只接受季度 float

python - 使用 GOOGLE Analytics API - 指标/维度

google-analytics - Google Analytics-堆积柱形图-如何添加更多X轴刻度线

google-analytics - Adwords 转换通过 React 引发了谷歌分析

google-analytics - 有没有办法让每个用户访问的页面生成报告?

javascript - <video> 使用 MediaRecorder() 从 <canvas> 播放录制的流,使用 canvas.captureStream() 在 firefox、chromium 上呈现不同的效果

javascript toFixed(2) 不工作

javascript - 如何在 hashchange 上完成目标?

php - google analytics api 查询特定的 url