我在实现谷歌分析到我的Rails 4项目时遇到了一些困难。我把跟踪代码放在了布局文件的底部,并尝试根据此处的建议删除了Turbolinks,但谷歌仍然无法检测到这个跟踪cookie。有什么想法吗?
我在实现谷歌分析到我的Rails 4项目时遇到了一些困难。我把跟踪代码放在了布局文件的底部,并尝试根据此处的建议删除了Turbolinks,但谷歌仍然无法检测到这个跟踪cookie。有什么想法吗?
几天前我设置了谷歌分析..
1.) Turbolink的解决方案
使用Turbolinks时,仅使用Google Analytics JavaScript库无法记录每个页面更新的访问量。
需要在每个页面上加载解决方案,可以将其作为应用程序范围的资源进行包含(它将在Turbolinks之前加载)。
添加文件app/assets/javascripts/analytics.js.coffee
以包含Turbolinks的解决方案:
app/assets/javascripts/analytics.js
// Coffee
$(document).on 'page:change', ->
if window._gaq?
_gaq.push ['_trackPageview']
else if window.pageTracker?
pageTracker._trackPageview()
// Javascript
$(document).on('page:change', function() {
if (window._gaq != null) {
return _gaq.push(['_trackPageview']);
} else if (window.pageTracker != null) {
return pageTracker._trackPageview();
}
});
2.) 创建页脚部分
在app/views/layouts
目录下创建一个局部文件 -> _footer.html.erb
然后在你的application.html.erb中调用你的局部文件 -> <%= render 'layouts/footer' %>
将Analytics跟踪代码插入到页脚中:
<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','//www.google-analytics.com/analytics.js','ga');
ga('create', 'UA-XXXXXXX-XX', 'herokuapp.com');
ga('send', 'pageview');
</script>
您需要将跟踪ID中的UA-XXXXXXX-XX替换为您自己的跟踪ID,并且如果您有任何域名,则需要将herokuapp.com替换为您的域名。
这是不使用 Coffeescript 的代码:
app/assets/javascripts/analytics.js
$(document).on('page:change', function() {
if (window._gaq != null) {
return _gaq.push(['_trackPageview']);
} else if (window.pageTracker != null) {
return pageTracker._trackPageview();
}
});
gem 'google-analytics-rails', '1.1.0'
bundle install
最后,这是关于生产环境配置的内容:
仅适用于生产环境 config/environments/production.rb:
# replace this with your tracker code
GA.tracker = "UA-112233-4"
在<head>
标签中的app/views/layout/application.html.erb文件:
<%= analytics_init if GoogleAnalytics.valid_tracker? %>
我在将代码推送到Heroku后立即看到了结果。
# If Turbolinks is supported, set up a callback to track pageviews on page:change.
# If it isn't supported, just track the pageview now.
if typeof Turbolinks isnt 'undefined' and Turbolinks.supported
document.addEventListener "page:change", (->
GoogleAnalytics.trackPageview()
), true
else
GoogleAnalytics.trackPageview()
我在使用turbolinks添加GA时遇到了一些问题,所以我参考了一些博客和stackoverflow上的答案,并写了一篇小博客。请参考此链接http://tarungarg402.blogspot.in/2015/01/google-analyicts-wth-rails.html
我在我的Rails应用程序中使用这个。我只是把它放在我的application.js.erb
文件中。
// GA racking code
(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-XXXXX-<%= Rails.env.production? ? '1' : '2' %>', 'auto');
// I have 2 GA properties- one for debug and another for production
// accommodate Turbolinks and track page views
$(document).on('ready page:change', function() {
ga('send', 'pageview');
});