假设我在不同模块下有三个同名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) {
});
答案 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;
}]);
两者有不同的价值观!
希望这有帮助!