gpt4 book ai didi

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

转载 作者:数据小太阳 更新时间:2023-10-29 05:10:21 24 4
gpt4 key购买 nike

假设我有一个名为 App 的模块,它注入(inject)了另外两个名为 factoriescontrollers 的模块:

var app = angular.module("app", ["factories", "controllers", "directives"])
.run(function ($rootScope, userFactory) {
userFactory.property = "someKickstartValue";
});

factories 模块包含所有工厂:

var factories = angular.module("factories", []),
factory = factories.factory("testFactory", {
property: "someValue"
});

controllers 模块包含所有 Controller :

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”不适用于 Controller ?据我所知,模块 app 有它自己的 testFactory 实例,模块 controllers 也有它自己的,所以不能是通过工厂在模块之间共享的任何信息。有解决办法吗,还是我弄错了?

最佳答案

我通过删除 Controller 的“工厂”依赖项来修复它。

var controllers = angular.module("controllers", []),
controller = controllers.controller("controller", function ($scope, testFactory) {
console.log(testFactory.property); // Returns "someKickstartValue" as expected
});

因为我现在没有将factories 声明为依赖项,controllers 模块不会创建它自己的factories 实例并且可以访问app 模块的实例,它注入(inject)了 controllers 模块。

关于javascript - AngularJS:在多个模块之间共享工厂,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/21598885/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com