analytics.js事件无法正常工作

时间:2013-08-25 11:53:27

标签: javascript javascript-events google-analytics analytics.js

我在ASPX webapplication中实现了analytics.js(新版本)。 我的网页浏览工作得很好,但事件往往没有被发送。

在我的例子中,我尝试按下3个不同的按钮,但只有其中一个按下了该事件。 我为每个事件添加了一个警告框,以验证它是否实际被触发,并且这些都显示出来。

Fiddler 这是我的js,放在</head>

之前
(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-XXXXXXXX-1', {
    'cookieDomain': 'none'
});
ga('send', 'pageview', {
    'page': '/team/main',
    'title': 'Logged in'
});

$(document).ready(function() {
    $(".team_button").on("click", function() {
        ga('send', 'event', 'button', 'click', 'Team select button', {
            'page': '/team/'
        })
    });
    $(".calendar_month_prev").on("click", function() {
        ga('send', 'event', 'button', 'click', 'Calendar: Prev month', {
            'page': '/team/'
        })
    });
    $(".calendar_month_next").on("click", function() {
        ga('send', 'event', 'button', 'click', 'Calendar: Next month', {
            'page': '/team/'
        })
    });
    $(".calendar_day_selected").on("click", function() {
        ga('send', 'event', 'button', 'click', 'Calendar: Same day reload', {
            'page': '/team/'
        })
    });
    $(".calendar_day_active").on("click", function() {
        ga('send', 'event', 'button', 'click', 'Calendar: Select day', {
            'page': '/team/'
        })
    });
});

4 个答案:

答案 0 :(得分:5)

当加载新页面时,当前页面上的待处理请求被取消 - 在这种情况下是分析跟踪像素请求。 'async'更多地指的是加载分析javascript代码然后处理分析数据。

对于ga.js,一种常见的方法是停止传播click事件,发送事件,然后在跟踪链接之前延迟少量(150ms)。

使用analytics.js,您可以使用hitCallback在发送分析数据后运行代码,而不是延迟。 请参阅Google Analytics文档中的Setting the Hit Callback

答案 1 :(得分:1)

好的,这是我修复它的方法,如果其他人有同样的问题:

我创建了一个函数,调用分析跟踪,我将页面延迟了几分之一秒:

function TrackEvent(link, category, action, label, page) {
    try {
        ga("send", "event", category, action, label, { 'page': page });
    } catch (err) { consol.log(err); }

    setTimeout(function () {
        document.location.href = link.href;
    }, 25);
}

然后,我的每个onClick绑定调用此函数,如下所示:

$(document).ready(function () {
    $(".calendar_month_prev").on("click",function(){ TrackEvent(this, 'button', 'click', 'Calendar: Prev month', '/team/main'); return false;});
    $(".calendar_month_next").on("click",function(){ TrackEvent(this, 'button', 'click', 'Calendar: Next month', '/team/main'); return false;});
    $(".calendar_day_active").on("click",function(){ TrackEvent(this, 'button', 'click', 'Calendar: Select day', '/team/main'); return false;});
});

如果首选,可以将其添加到on href onClick:)

答案 2 :(得分:1)

我建议在成功注册事件后执行虚拟锚点击:

a.onclick = function(e){
            var anchor = this;
            _gaq.push(['_trackEvent', 'Category','event','label']);
            _gaq.push(function() {
                var a = document.createElement('a');
                a.href = anchor.href;
                a.target = anchor.target;
                a.click();
            });
            return false;
        }

由于push作为队列工作,您的事件请求永远不会被取消..

答案 3 :(得分:0)

正如迈克所指出的,在这种情况下你应该使用点击回调。此外,您还需要考虑用户可能会使用某些隐私保护工具(例如Ghostery)阻止Google Analytics,在这种情况下,点击回调将永远不会被执行。因此,您需要非常仔细地实施此操作,以便您的网站即使对这些用户也能继续工作。以下文章解释了如何正确执行此操作:

http://veithen.github.io/2015/01/24/outbound-link-tracking.html