首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >AngularJS:在多个模块之间共享工厂

AngularJS:在多个模块之间共享工厂
EN

Stack Overflow用户
提问于 2014-02-06 09:35:21
回答 2查看 3.6K关注 0票数 6

假设我有一个名为App的模块,它注入了另外两个称为工厂和控制器的模块

代码语言:javascript
复制
var app = angular.module("app", ["factories", "controllers", "directives"])
.run(function ($rootScope, userFactory) {
    userFactory.property = "someKickstartValue";
});

工厂模块包含所有工厂:

代码语言:javascript
复制
var factories = angular.module("factories", []),
factory = factories.factory("testFactory", {
     property: "someValue"
});

控制器模块包含所有控制器:

代码语言:javascript
复制
var controllers = angular.module("controllers", ["factories"]),
controller = controllers.controller("controller", function ($scope, testFactory) {
    console.log(testFactory.property); // Returns "Some Value" and not 
                                       // "someKickstartValue" as expected.
});

的实际问题:

为什么"someKickstartValue“不适用于控制器?据我所知,模块应用程序有自己的testFactory实例,模块控制器也有自己的实例,因此不能通过工厂在模块之间共享任何信息。有办法绕道吗,还是我弄错了?

EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2014-02-06 17:42:11

我通过删除控制器的“工厂”依赖来修正它。

代码语言:javascript
复制
var controllers = angular.module("controllers", []),
controller = controllers.controller("controller", function ($scope, testFactory) {
    console.log(testFactory.property); // Returns "someKickstartValue" as expected
});

因为我现在不声明工厂是依赖的,所以控制器模块不会创建它自己的工厂实例,并且可以访问注入控制器模块的app模块的实例。

票数 6
EN

Stack Overflow用户

发布于 2015-07-29 09:43:06

我也面临着同样的问题。我用以下方法解决了这个问题:

代码语言:javascript
复制
// modules.js
(function (angular) {
    angular.module("shared", []);
    angular.module("user", ["shared"]);
    angular.module("admin", ["shared"]);
})(window.angular);

这种结构允许在其他模块中使用附加到共享模块的工厂、服务和指令。

票数 3
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/21598885

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档