6

我有一个配置,我希望能够注入到 Angular 服务、指令等中。这样做的最佳方法是什么?

我正在玩制作配置模块的想法:

'use strict';
angular.module('config', [])

但我不确定如何构造将成为注入的实际配置对象的对象文字:

angular.module('myModule', ['ngResource', 'config'])
  .factory('myservice', function ($resource) {
        return $resource(config.myservice,{}, {
          // whatever
        })
  });

将配置公开为服务并注入它可以吗?

4

2 回答 2

9

我想说,策略会有所不同,具体取决于您拥有的配置类型,但您有多种选择:

模块范围的常量

如果你只需要几个常量,你可以使用.value(),像这样:

var app;

app = angular.module("my.angular.module", []);

app.value("baseUrl", "http://myrestservice.com/api/v1");

//injecting the value
app.controller("MyCtrl", ['baseUrl', function (baseUrl) {
  console.log(baseUrl); // => "http://myrestservice.com/api/v1"
}]);

在此处查看更详细的答案。

获取配置/配置服务

我个人喜欢做的是像往常一样通过服务从其他地方获取我的配置。没关系,这是一个远程位置还是只是静态信息。

var app;

app = angular.module("my.angular.config", []);

app.service('Configuration', [function() {
  return {
    getbaseUrl: function() { return "http://myrestservice.com/api/v1" },
    getConfig: function() {
      return {
        answer: 42,
        question: "??"
      }
    }
  }
}]):

编辑:带有外部提取的示例:

var app;

app = angular.module('my.module.config', []);

app.factory('ConfigurationData', ['$http', '$q', function(http, q) {
  var deferredConfig = q.defer();

  //error handling ommited
  http.get('http://remote.local/config.json').success(function(data) {
    return deferredConfig.resolve(data);
  });

  return {
    getConfig: function() {
      return deferredConfig.promise;
    }
  };
}]);

使用此服务,您可以将配置注入其他服务,但是,您可能会遇到时间问题,因为您必须先注入并解决服务提供的承诺,然后才能对配置进行任何操作:

var app;

app = angular.module("my.other.module", ['my.module.config']);

app.factory('MyAwesomeService', ['ConfigurationData', function(config) {
  config.getConfig().then(function(config) {
    //do something with your config.
  });
}]);

您可以在这里获得更精细的控制,因为您可以对不同的输入做出反应。同样,这取决于您的用例。如果您需要额外的逻辑来构建配置,您可以在此处使用工厂。

最后,如果您想要更多地控制配置,您可以创建一个

自定义提供程序

提供者可能非常有用,但我认为它们设计起来有点困难。考虑到baseUrl应用程序运行所需的配置,您可以为需要如下值的服务编写提供程序baseUrl

var app;

app = angular.module('my.angular.module', []);

app.provider("RestServiceProvider", function(){

  this.baseUrl = 'http://restservice.com';

  this.$get = function() {
    var baseUrl = this.baseUrl;
    return {
        getBaseUrl: function() { return this.baseUrl; }
    }
  };

  this.setBaseUrl = function(url) {
    this.baseUrl = url;
  };
});

这使您可以在应用程序的配置阶段做一些很酷的事情:

app.config(['RestserviceProvider', function(restServiceProvider) {

  restServiceProvider.setBaseUrl('http://wwww.myotherrestservice.com');

}]);

您在服务/控制器/等中获取的每个实例。从您注入它的那一刻起,ofRestService现在将拥有baseUrl配置阶段的集合。

对于更详细的概述,我建议这个要点

于 2013-08-03T21:29:55.980 回答
7

创建仅具有服务或指令(或两者)的独立模块是制作独立于应用程序的 Angular 代码的好方法。如果您这样做,您可以轻松地将该 .js 文件放入任何项目中,您所需要做的就是将其注入您的应用程序中,它就可以工作了。

所以做类似的事情:

angular.module('config', [])
    .factory('config', function() {
        return {
            theme : 'nighttime',
            cursor : 'sword',
            ...
        };
    });

然后你可以像这样将它注入到任何应用程序中:

angular.module('myModule', ['config'])
    .factory('myservice', function (config) {
        var theme = config.theme;
        var cursor = config.cursor;
        // do stuff with night-time swords!
    });

这实际上是 angular-ui 团队打包所有指令的方式,每个指令都包含在自己的模块中,这使得其他人可以轻松地获取该代码并在所有应用程序中重用它。

于 2013-08-03T21:11:58.713 回答