本文介绍了访问angularjs另一个模块中定义的工厂的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!
问题描述
我们可以从另一个模块中调用一个模块中定义的工厂功能吗?如果可以,怎么办?
Can we call the factory functions defined in one module from another module? If so, how?
假设我的第一个模块在moduleOne.js
文件中定义为:
Let's say my first module is defined in moduleOne.js
file as:
var myModule = angular.module('MyServiceModuleOne', []);
myModule.factory('notify', function () {
return {
sampleFun: function () {
// some code to call sampleFunTwo()
},
};
});
我在moduleTwo.js
中的第二个模块为:
And my second module in moduleTwo.js
as:
var myModuleTwo = angular.module('MyServiceModuleTwo', []);
myModuleTwo.factory('notifytwo', function () {
return {
sampleFunTwo: function () {
// code
},
};
});
如何从sampleFun()
调用sampleFunTwo()
?
谢谢.
推荐答案
您需要注入 MyServiceModuleTwo
到MyServiceModule
:
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
这篇关于访问angularjs另一个模块中定义的工厂的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持!