AngularJS:注入名称相同但模块不同的工厂/服务

时间:2014-02-06 05:05:00

标签: angularjs angularjs-service

假设我在不同模块下有三个同名DSerrorLog的工厂

angular.module('module1').factory('DSerrorLog', function () {
    return { show: false, msg: "" };
});
angular.module('module2').factory('DSerrorLog', function () {
    return { show: false, msg: "" };
});
angular.module('module3').factory('DSerrorLog', function () {
    return { show: false, msg: "" };
});

如何从正确的模块中注入正确的实例,例如DSerrorLog下的module3进入我的控制器?我认为诸如module3.DSerrorLog之类的语法在这里不起作用。

angular.module('mainApp', ['module1', 'module2', 'module3'])
    app.controller('MainCtrl', function ($scope, DSerrorLog) {
});

1 个答案:

答案 0 :(得分:8)

很酷的问题!

事实证明,您包含它们的顺序会影响您获得的顺序。基本上每个添加的模块都会覆盖注入器。因此,在您的示例中,如果您正常注入,则DSerrorLog将来自module3。

如果你想使用它们,你仍然可以获得其他模块的注射器。这是一个小提琴,我展示了如何做到这一点:http://jsfiddle.net/7YH7p/

app.controller('myCtrl', ['$scope', '$injector', 'test', 
    function($scope, $injector, test) {
        $scope.injected = test.data;
        var inj = angular.injector(['mod1']);
        $scope.my_inject = inj.get('test').data;
}]);

两者有不同的价值观!

希望这有帮助!