我在 Angular 中创建了一个如下所示的控制器(为简洁起见进行了编辑):
function AppCtrl($scope, $http, $location, $dataService) {
$scope.projects = $dataService.data.projects;
}
这正确地加载了我的服务的$scope.projects
承诺。$dataService
app.service('$dataService', function($q, $http, $location, $rootScope) {
var dataService = this; //Provides access 'this' inside functions below
var projectsDeferred = $q.defer();
$http.get('/api').success(function(data, status, headers, config) {
projectsDeferred.resolve(data.projects);
}).error(function(err) {
projectsDeferred.reject(err);
});
this.data = {projects: projectsDeferred.promise};
//UPDATE FUNCTION
function updateObjectInArray(array, object, newData) {
for(i in array) {
if(array[i] == object) {
if(newData != undefined) {
array[i] = newData;
} else {
return array[i];
}
}
}
return undefined;
}
this.updateProject = function(project, updateData) {
$http.put('/api/projects/' + project._id, updateData)
.success(function(data, status, headers, config) {
updateObjectInArray(dataService.data.projects.$$v, project, data);
}).error(function(data, status, headers, config) {});
};
});
我创建了另一个看起来像这样的控制器,它根据当前 URL 从项目数组中选择一个项目:
function ProjectCtrl($scope, $route) {
//Getting the current project from the array of projects
$scope.project = $scope.projects.then(function(projects) {
for(i in projects) {
if(projects[i]._id == $route.current.params.projectId) {
return projects[i];
}
}
});
}
当我尝试运行我的updateObjectInArray()
函数时(在我的$http.put()
请求成功时),我$scope.projects
的 inAppCtrl
已正确更新(项目数组)但我的$scope.project
inProjectCtrl
未更新。我可以在函数内部登录,它会准确地记录我的期望,我可以登录,它会相应地更新,但是当我尝试登录我的控制器时,它不会相应地更新。array[i]
updateObjectInArray()
$scope.projects
AppCtrl
$scope.project
ProjectCtrl
我认为原因是因为我必须调用$rootScope.$apply()
或者$rootScope.$digest()
在我更新了中的array[i]
对象之后updateObjectInArray()
,但是,我得到了$digest is already in progress
.
我需要做些什么来确保我$scope.project
的数组中的项目在我的ProjectCtrl
? 我需要为它解决一个新的承诺吗?