AngularJS:使用Google Analytics的正确方法

时间:2014-07-29 11:28:01

标签: angularjs dependency-injection google-analytics google-analytics-v4

我想知道哪种方法可以将Google Analytic集成到我的AngularJS应用中。我想通过DI提供它,所以我可以在单元测试期间模拟它,并测试哪些数据被发送到它。

我正在尝试这样的事情:

.service('$ga', function () {
    (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', 'GA_KEY', 'auto');
    ga('send', 'pageview');
    return ga;
})

但当然它不起作用,因为第一个是虚拟对象,当analytics.js加载时,用适当的实现替换window.qa(即:window[document['GoogleAnalyticsObject']])。因此,当服务运行时,返回虚拟实现。

我想使用提供程序将是正确的方法,因为我还想配置一些参数(如UserID等...),但我不知道如何设置它。

哪种方法正确?

1 个答案:

答案 0 :(得分:0)

这是我到目前为止所做的最好的事情:

.provider('$ga', function () {

    window['GoogleAnalyticsObject'] = 'ga';
    window['ga'] = window['ga'] || function () { (window['ga'].q = window['ga'].q || []).push(arguments)}
    window['ga'].l = 1 * new Date();
    var script = document.createElement('script');
    var prevScript = document.getElementsByTagName('script')[0];
    script.async = 1;
    script.src = '//www.google-analytics.com/analytics.js';
    prevScript.parentNode.insertBefore(script, prevScript);

    var provider = function () {
        var me = {};

        me.$get = function () {
            ga('send', 'pageview');
            return function () {                
                return window.ga.apply(window, arguments);
            }
        };

        me.ga = function () {
                return window.ga.apply(window, arguments);
        };

        return me;
    };

    return provider();
})

这是一个可以配置的提供程序:

.config(['$gaProvider',function ($gaProvider) {
    $gaProvider.ga('create','UA-XXXXXX-Y','auto');
}])

欢迎反馈。