本文介绍了访问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()?

谢谢.

推荐答案

您需要注入 MyServiceModuleTwoMyServiceModule:

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

然后注入 notifytwonotify:

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


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

以及 plunker

这篇关于访问angularjs另一个模块中定义的工厂的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持!

09-24 21:07