这对我有用:
window.ga = window.ga || function(){};
我从原始跟踪代码 ( https://developers.google.com/analytics/devguides/collection/analyticsjs/ ) 片段中获取它:
(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');
基本相同的检查
i[r] = i[r] || function() {
…
}
i 是窗口对象,r 是分析函数名称的名称。当函数调用自身时,两者都被传递
(window,document,'script','//www.google-analytics.com/analytics.js','ga');
一般来说,分析代码本身无论如何都是异步加载的,所以如果你把它放在标题中应该不会有太大的伤害。
更新:我找到了在本地主机上加载谷歌分析而不在这里发送测试数据的正确方法https://developers.google.com/analytics/devguides/collection/analyticsjs/advanced,对于本地主机使用以下代码:
ga('create', 'UA-XXXX-Y', {
'cookieDomain': 'none'
});
(旧:我必须检查/定义“ga”,因为在我的本地开发环境中我根本不加载分析代码,所以我会得到一个参考错误。(