---我知道这个答案不适用于这个问题,但我希望阅读这个问题并想要处理工厂等服务的人避免这样做----
为此,您将需要使用服务或工厂。
这些服务是在非嵌套控制器之间共享数据的最佳实践。
关于数据共享这个主题的一个非常好的注释是如何声明对象。我很不幸,因为我在阅读之前就陷入了 AngularJS 的陷阱,我非常沮丧。所以让我帮你避免这个麻烦。
我从“ng-book: The complete book on AngularJS”中读到,在控制器中作为裸数据创建的 AngularJS ng-model 是错误的!
应该像这样创建一个 $scope 元素:
angular.module('myApp', [])
.controller('SomeCtrl', function($scope) {
// best practice, always use a model
$scope.someModel = {
someValue: 'hello computer'
});
而不是这样:
angular.module('myApp', [])
.controller('SomeCtrl', function($scope) {
// anti-pattern, bare value
$scope.someBareValue = 'hello computer';
};
});
这是因为建议(最佳实践)DOM(html 文档)将调用包含为
<div ng-model="someModel.someValue"></div> //NOTICE THE DOT.
如果您希望您的子控制器能够从父控制器更改对象,这对嵌套控制器非常有帮助......
但是在您的情况下,您不需要嵌套范围,但是有一个类似的方面可以将对象从服务获取到控制器。
假设您有您的服务“工厂”,并且在返回空间中有一个包含 objectB 的 objectA,其中包含 objectC。
如果您想从您的控制器中将 objectC 获取到您的范围内,那么这样说是错误的:
$scope.neededObjectInController = Factory.objectA.objectB.objectC;
那行不通……
而是只使用一个点。
$scope.neededObjectInController = Factory.ObjectA;
然后,在 DOM 中,您可以从 objectA 调用 objectC。这是与工厂相关的最佳实践,最重要的是,它将有助于避免意外和不可捕获的错误。