将 Angulartics 和 Google Analytics 用于动态和唯一 URL
Using Angulartics and Google Analytics for Dynamic and Unique URLs
我正在尝试在我的 AngularJS SPA 中使用 angulartics and Google Analytics,这样即使当用户处于应用程序。当用户从一个页面移动到另一个页面(以及一个状态到另一个状态)时,URL 将继续依赖自身,包括 GUID。请参阅下面的示例:
- 第 1 页:localhost:9000/selectListing
- 第 2 页:localhost:9000/34ea85a0-84db-4443-b40b-f7e0b6b0b096/selectFiles
- 第 3 页:localhost:9000/34ea85a0-84db-4443-b40b-f7e0b6b0b096/addUser/ceb1639a-1ba4-4f09-a175-474bea0fe3bf
当我在 google 分析上查看此信息时,每次用户在实时页面视图列表下的 selectFiles 页面上时,我都会看到一个唯一的 URL。例如:
- localhost:9000/34ea85a0-84db-4443-b40b-f7e0b6b0b096/selectFiles
- localhost:9000/0c006d26-bff4-43da-aaee-d332f92b05db/selectFiles
我只想看到它聚合在一起,这样 /selectFiles 页面上就会有一个用户计数
这是我的 index.html 文件中的 google 分析代码:
if (window.location.host.indexOf('cats.kittens.com') >=0){
(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-5555555-5', 'auto');
$window.ga('send', 'pageview', { page: $location.url() });
这是我在 app.js 文件中实现的代码:
angular.module('myApp', [
'ui.router', 'ui.bootstrap', 'ui.bootstrap.tpls', 'ngTable', 'ngSanitize', 'angularFileUpload','angular.filter', 'angulartics', 'angulartics.google.analytics',
])
/* Angulartics configuration */
.config(['$analyticsProvider', function ($analyticsProvider) {
$analyticsProvider.firstPageview(false); /* Records pages that don't use $state or $route */
$analyticsProvider.withAutoBase(true); /* Records full path */
}])
.config(['$stateProvider', '$urlRouterProvider', '$logProvider', function ($stateProvider, $urlRouterProvider, $logProvider) {
'use strict';
// global $log.debug setting
$logProvider.debugEnabled(true);
}]);
我已经用 google 分析和 ui-路由器尝试过这个解决方案,但没有成功:http://www.arnaldocapo.com/blog/post/google-analytics-and-angularjs-with-ui-router/72
请让我知道我可以尝试的任何其他方法。提前致谢!
在 github 上对这个问题进行了几天的研究后,我找到了解决方案。我将此 运行 块添加到我的 app.js 文件中:
.run(['$rootScope', '$stateParams', '$analytics', '$location', '$log', function($rootScope, $stateParams, $analytics, $location, $log) {
$rootScope.$on('$stateChangeSuccess', function (event, toState, toParams) {
var overrideStateParams = {};
var flattener = null;
if (toState.angulartics && toState.angulartics.flattenParams === true)
{
angular.forEach(toParams, function(v,k) {
overrideStateParams[k] = ':' + k;
});
}
else if (toState.angulartics && angular.isArray(toState.angulartics.flattenParams))
{
angular.forEach(toState.angulartics.flattenParams, function(flattenParam) {
overrideStateParams[flattenParam] = ':' + flattenParam;
});
}
else
{
// default is to not flatten
}
var url = location.host + decodeURIComponent(location.hash);
url = url.replace(/#/, '/').replace(/\/+/g, '/').replace(/([0-9a-f]{8}-[0-9a-f]{4}-[0-9a-f]{4}-[0-9a-f]{4}-[0-9a-f]{12})/ig, 'GUID');
$log.info(url);
$analytics.pageTrack(url);
});
}])
请注意,我在上面的代码中用正则表达式替换了 GUID。您可能需要更改正则表达式以满足您对独特 URL 的需求。
我还将这段代码添加到我需要 URL t运行cated:
的每个状态
angulartics: { flattenParams: true }
您可以在路由配置文件中按状态实现它:
.state('Kittens.meow', {
url: '/meow',
templateUrl: 'meow/hiss.html',
angulartics: { flattenParams: true }
})
我正在尝试在我的 AngularJS SPA 中使用 angulartics and Google Analytics,这样即使当用户处于应用程序。当用户从一个页面移动到另一个页面(以及一个状态到另一个状态)时,URL 将继续依赖自身,包括 GUID。请参阅下面的示例:
- 第 1 页:localhost:9000/selectListing
- 第 2 页:localhost:9000/34ea85a0-84db-4443-b40b-f7e0b6b0b096/selectFiles
- 第 3 页:localhost:9000/34ea85a0-84db-4443-b40b-f7e0b6b0b096/addUser/ceb1639a-1ba4-4f09-a175-474bea0fe3bf
当我在 google 分析上查看此信息时,每次用户在实时页面视图列表下的 selectFiles 页面上时,我都会看到一个唯一的 URL。例如:
- localhost:9000/34ea85a0-84db-4443-b40b-f7e0b6b0b096/selectFiles
- localhost:9000/0c006d26-bff4-43da-aaee-d332f92b05db/selectFiles
我只想看到它聚合在一起,这样 /selectFiles 页面上就会有一个用户计数
这是我的 index.html 文件中的 google 分析代码:
if (window.location.host.indexOf('cats.kittens.com') >=0){
(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-5555555-5', 'auto');
$window.ga('send', 'pageview', { page: $location.url() });
这是我在 app.js 文件中实现的代码:
angular.module('myApp', [
'ui.router', 'ui.bootstrap', 'ui.bootstrap.tpls', 'ngTable', 'ngSanitize', 'angularFileUpload','angular.filter', 'angulartics', 'angulartics.google.analytics',
])
/* Angulartics configuration */
.config(['$analyticsProvider', function ($analyticsProvider) {
$analyticsProvider.firstPageview(false); /* Records pages that don't use $state or $route */
$analyticsProvider.withAutoBase(true); /* Records full path */
}])
.config(['$stateProvider', '$urlRouterProvider', '$logProvider', function ($stateProvider, $urlRouterProvider, $logProvider) {
'use strict';
// global $log.debug setting
$logProvider.debugEnabled(true);
}]);
我已经用 google 分析和 ui-路由器尝试过这个解决方案,但没有成功:http://www.arnaldocapo.com/blog/post/google-analytics-and-angularjs-with-ui-router/72
请让我知道我可以尝试的任何其他方法。提前致谢!
在 github 上对这个问题进行了几天的研究后,我找到了解决方案。我将此 运行 块添加到我的 app.js 文件中:
.run(['$rootScope', '$stateParams', '$analytics', '$location', '$log', function($rootScope, $stateParams, $analytics, $location, $log) {
$rootScope.$on('$stateChangeSuccess', function (event, toState, toParams) {
var overrideStateParams = {};
var flattener = null;
if (toState.angulartics && toState.angulartics.flattenParams === true)
{
angular.forEach(toParams, function(v,k) {
overrideStateParams[k] = ':' + k;
});
}
else if (toState.angulartics && angular.isArray(toState.angulartics.flattenParams))
{
angular.forEach(toState.angulartics.flattenParams, function(flattenParam) {
overrideStateParams[flattenParam] = ':' + flattenParam;
});
}
else
{
// default is to not flatten
}
var url = location.host + decodeURIComponent(location.hash);
url = url.replace(/#/, '/').replace(/\/+/g, '/').replace(/([0-9a-f]{8}-[0-9a-f]{4}-[0-9a-f]{4}-[0-9a-f]{4}-[0-9a-f]{12})/ig, 'GUID');
$log.info(url);
$analytics.pageTrack(url);
});
}])
请注意,我在上面的代码中用正则表达式替换了 GUID。您可能需要更改正则表达式以满足您对独特 URL 的需求。 我还将这段代码添加到我需要 URL t运行cated:
的每个状态angulartics: { flattenParams: true }
您可以在路由配置文件中按状态实现它:
.state('Kittens.meow', {
url: '/meow',
templateUrl: 'meow/hiss.html',
angulartics: { flattenParams: true }
})