在下面的人为示例中,我已经弄清楚了如何使用共享服务在两个 AngularJS 控制器之间共享数据:
(功能小提琴)
var app = angular.module('myApp', []);
app.factory('UserData', function() {
var data = {foo: 'bar'};
return {
getData: function() {
console.log('getData');
return data;
},
setData: function(newData) {
data = newData;
}
};
});
function MainCtrl($scope, UserData) {
console.log('MainCtrl');
console.log(UserData.getData());
}
MainCtrl.$inject = ['$scope', 'UserData'];
function JobListCtrl($scope, UserData) {
console.log('JobListCtrl');
console.log(UserData.getData());
}
JobListCtrl.$inject = ['$scope', 'UserData'];
我的问题是我希望保存的数据UserData
来自 Ajax 调用(大概使用$http
)。
UserData
我尝试在工厂函数中进行 Ajax 调用,但是因为它是异步运行的,MainCtrl
并且在服务中实际包含任何数据JobListCtrl
之前执行。UserData
有人可以给我一些关于如何设置的指导吗?