访问angularjs中另一个模块中定义的工厂

时间:2013-09-04 06:38:40

标签: javascript angularjs dependency-injection module

我们可以从另一个模块调用一个模块中定义的工厂函数吗?如果是这样,怎么样?

假设我的第一个模块在moduleOne.js文件中定义为:

var myModule = angular.module('MyServiceModuleOne', []);
myModule.factory('notify', function () {
    return {
        sampleFun: function () {
            // some code to call sampleFunTwo()
        },
    };
});

我在moduleTwo.js的第二个模块:

var myModuleTwo = angular.module('MyServiceModuleTwo', []);
myModuleTwo.factory('notifytwo', function () {
    return {
        sampleFunTwo: function () {
            // code
        },
    };
});

如何从sampleFunTwo()致电sampleFun()

感谢。

1 个答案:

答案 0 :(得分:45)

您需要注入 MyServiceModuleTwoMyServiceModule

var myModuleTwo= angular.module('MyServiceModuleTwo',[]);
var myModule= angular.module('MyServiceModuleOne', ['MyServiceModuleTwo']);

然后 notifytwo注入notify

myModule.factory('notify', function(notifytwo) {
    return {
        sampleFun: function() {
            notifytwo.sampleFunTwo();
        }      
    };
});


myModuleTwo.factory('notifytwo', function() {
    return {
        sampleFunTwo: function() {
            alert('From notify two');
        }    
    };
}); 

plunker上的代码