련:올바른 접근을 위해 Google 애널리틱스를 사용하는
문제
는지 궁금하는 올바른 방법으로 통합 구글 분석으로 내련 app.나는 그것을 제공해 DI,할 수 있도록 모 그 동안 단위 테스트,그리고 테스트하는 데이터가 전송되니다.
I was trying something like this:
.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
(ie:window[document['GoogleAnalyticsObject']]
은)적절한 구현.그래서 때 서비스를 실행하는 반환합니다 dummy 구현합니다.
나는 사용하는 공급자가 될 것입니다 올바른 방법으로,이후 나는 또한 일부를 구성 매개변수(같은 사용자 Id,etc.),하지만 나는 아이디어가 어떻게 그것을 설정하는 방법입니다.
는 올바른 접근법?
해결책
이 나는 지금까지:
.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');
}])
피드백을 환영합니다.
제휴하지 않습니다 StackOverflow