将Angulartics和Google Analytics用于动态和唯一网址

时间:2015-09-15 00:07:15

标签: javascript angularjs google-analytics angulartics

我正在尝试在我的AngularJS SPA中使用angularticsGoogle Analytics,这样即使构建的网址在用户位于应用中时,我也能够聚合网页浏览。当用户从一个页面移动到另一个页面(以及状态到状态)时,URL将继续构建自身,包括GUID。请参阅下面的示例:

  1. 第1页:localhost:9000 / selectListing
  2. 第2页:localhost:9000 / 34ea85a0-84db-4443-b40b-f7e0b6b0b096 / selectFiles
  3. 第3页:localhost:9000 / 34ea85a0-84db-4443-b40b-f7e0b6b0b096 / addUser / ceb1639a-1ba4-4f09-a175-474bea0fe3bf
  4. 当我在google analytics上查看此信息时,每次用户在实时页面浏览列表下的selectFiles页面上时,我都会看到一个唯一的URL。例如:

    1. 本地主机:9000 / 34ea85a0-84db-4443-b40b-f7e0b6b0b096 / selectFiles
    2. 本地主机:9000 / 0c006d26-bff4-43da-AAEE-d332f92b05db / selectFiles
    3. 我只想看到它聚合在一起,以便在/ 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);
      
      }]);
      

      我已经尝试使用谷歌分析和ui-router这个解决方案但没有成功:http://www.arnaldocapo.com/blog/post/google-analytics-and-angularjs-with-ui-router/72

      请让我知道其他任何我可能尝试的事情。提前谢谢!

1 个答案:

答案 0 :(得分:1)

在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的每个州:

angulartics: { flattenParams: true }

你可以在你的路由配置文件中按状态实现它:

            .state('Kittens.meow', {
                url: '/meow',
                templateUrl: 'meow/hiss.html',
                angulartics: { flattenParams: true }
            })