サーバーからいくつかのクライアント データをフェッチするサービスがあります。
app.factory('clientDataService', function ($http) {
var clientDataObject = {};
var cdsService = {
fetch: function (cid) {
//$http returns a promise, which has a then function, which also returns a promise
var promise = $http.get('/clients/stats/' + cid + '/').then(function (response) {
// The then function here is an opportunity to modify the response
console.log(response);
// The return value gets picked up by the then in the controller.
clientDataObject = {'data': response.data, 'currentClientID': cid};
return clientDataObject;
});
// Return the promise to the controller
return promise;
}
};
return cdsService;
});
次に、1つのコントローラーで次のことを行います。
//get stats
clientDataService.fetch($scope.id).then(function (response) {
$scope.client_data = {
'statistics': response.data
}
});
これはすべて非常にうまく機能します。ただし、そのサービスの別のコントローラーからウォッチを実行して、データが変更されたときにスコープを更新しようとしています。http 要求を再度開始する必要はありません。
$scope.$watch('clientDataService.clientDataObject', function (cid) {
alert(cid);
});
今のところ警告していますが、トリガーされることはありません。ページが最初に読み込まれると、「未定義」というアラートが表示されます。コンソールにエラーはなく、すべての $injects に問題はありませんが、サービスでデータが変更されたことを認識していないようです。時計で何か間違ったことをしていますか?
どうもありがとうベン