gpt4 book ai didi

AngularJS:使用 Google Analytics 的正确方法

转载 作者:行者123 更新时间:2023-12-03 06:25:55 25 4
gpt4 key购买 nike

我想知道将 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 等...),但我不知道如何设置它。

哪种方法是正确的?

最佳答案

这是我迄今为止得到的最好的:

.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');
}])

欢迎提供反馈。

关于AngularJS:使用 Google Analytics 的正确方法,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/25014204/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com