6

问题是 GA 有时需要一些时间来加载,而我的 jQuery ready() 函数在完成之前不会运行。我想将 GA 代码本身移到 ready() 函数的末尾。我不是在寻找额外的点击跟踪集成——我只是希望我的 ready() 脚本首先运行。

我的问题是:1)移动 GA 代码会以任何方式破坏他们的统计跟踪吗?而且,2)我是否需要模拟他们使用两个脚本标签(一个生成外部脚本标签,一个调用函数)?如果是这样,为什么,以及在 jQuery 函数中执行此操作的最佳方法是什么?

为了解释 #2,这是当前在结束 body 标记之前的 GA 代码:

<script type="text/javascript">
var gaJsHost = (("https:" == document.location.protocol) ? "https://ssl." : "http://www.");
document.write(unescape("%3Cscript src='" + gaJsHost + "google-analytics.com/ga.js' type='text/javascript'%3E%3C/script%3E"));
</script>
<script type="text/javascript">
try {
var pageTracker = _gat._getTracker("UA-8704511-1");
pageTracker._trackPageview();
} catch(err) {}</script>
4

3 回答 3

6

这里有一个类似的问题:

这里接受的答案是:

于 2009-05-12T15:12:00.477 回答
3

看起来 Google 也解决了这个问题 - 请参阅这个更新的Stack Overflow 问题

于 2010-02-25T16:10:44.157 回答
1

之所以有两个脚本块,是因为第一个块中的脚本在两个块之间插入了对 Google Analytics javascript 文件的引用。如果它们都在同一个块中,则跟踪器将在加载之前尝试初始化。所以#2 绝对正确,您需要拥有或模拟两个脚本标签。

于 2009-05-12T14:15:17.127 回答