2

首先,这是一个诚实的问题。我正在寻找关于为什么我应该这样做的诚实和合理的答案......

angular
    .module('X', ['Y'])
    .config(function (myFactoryProvider, myServiceProvider) {
        myFactoryProvider.$get().myFn();
        myServiceProvider.$get().myFn();
    });

angular
    .module('Y', [])
    .factory('myFactory', ['$location', function ($location) {
        return {
            myFn: function () {
                console.log('factory');
                console.log($location.absUrl());
            }
        }
    }])
    .service('myService', ['$location', function ($location) {
        this.myFn = function () {
            console.log('service');
            console.log($location.absUrl());
        }
    }]);

这是一个 JSFiddle:http: //jsfiddle.net/1vetnu6o/

正如您在上面看到的那样,这是有效的,它为我解决了一些问题。但我可能不应该这样做,我想了解原因。我真的需要充分的理由不这样做。尽管我真的很想。

tl;博士;

这是问题的背景......

我有多个产品使用的这个内部框架,其中有一个服务(恰好是一个工厂),它基本上包含一组相关的辅助方法。在这种情况下,设备相关,如isMobileDevice, isAndroid, getDeviceType(带有返回mobile,tabletdesktop),以及其他一些......

该服务必须config()使用框架注入到应用程序的阶段,因为我们需要访问该getDeviceType功能。问题是,我们需要deviceType使用$routeProvider. config()我们正在构建用于所有路由的正确模板路径的阶段。其中一些依赖于deviceType,而另一些则具有独立于设备的通用模板。

由于这是一项服务,我们无法将其直接注入config()阶段,但我们可以使用我在文章前面提到的技术调用该方法。

我目前如何解决这个问题?辅助服务实际上是一个提供者,所有方法都在提供者部分和工厂函数中公开。不理想,但它有效。我认为这是一种变通方法,但我宁愿在应用程序而不是框架中使用变通方法,因此首先提到了该技​​术。

想法?

4

2 回答 2

0

我不知道,但实际上你可以在配置阶段调用。问题是 myService 将被实例化两次:/

 angular
    .module('X', [])
    .config(function(myServiceProvider) {
      myServiceProvider.$get().myFn();
    })
    .run(function(myService) {
      myService.myFn();
    })
    .service('myService', ['$location', function($location) {
      console.log('myService!');
      this.myFn = function() {
        console.log($location.absUrl());
      }
    }]);

输出:

  "myService!"
  "location"
  "myService!"
  "location"

如果您在具有大嵌套依赖关系树的服务的配置上调用 $get,这很危险:/

于 2015-03-25T12:12:10.317 回答
0

我认为正确的方法,如果你需要一个实用服务(没有依赖),是使用一个常量(这样你可以在任何地方注入它)。否则,如果您需要依赖项,请使用服务并坚持 run() 块。

config() 块是指示您的服务如何在其提供者的帮助下工作的地方。

run() 块是在您的应用程序启动时执行一些逻辑的理想场所(又名 main 方法)。

于 2015-03-26T13:56:47.733 回答