私のサービスが $resource get から promise を返していると仮定すると、これがデータをキャッシュする適切な方法であるかどうか疑問に思います。この例では、戻る矢印を押して検索結果に戻った後、Web サーバーを既に持っているため、再度クエリを実行したくありません。これは、この状況を処理するための適切なパターンですか? 以下の例は、Flixter (Rotten Tomatoes) API を照会しています。
煮詰めたコード:
コントローラ:
function SearchCtrl($scope, $route, $routeParams, $location, DataService) {
DataService.search($routeParams.q).then(function(data){
$scope.movies = data.movies;
});
}
サービス:
angular.module('myApp.services', []).
factory('DataService', ['$q', '$rootScope', 'JsonService', function ($q, $rootScope, JsonService) {
var movie = {};
var searchResults = {};
var searchq = '';
var service = {
search: function(q) {
var d = $q.defer();
// checking search query, if is the same as the last one,
//resolve the results since we already have them and don't call service
// IS THIS THE CORRECT PATTERN
if (q==searchq) {
d.resolve(searchResults);
} else {
// returns a $resource with defined getdata
JsonService.search.movieSearch(q, 20, 1).getdata(function(data){
searchResults = data;
searchq = q;
d.resolve(searchResults);
});
}
return d.promise;
},
getSearchResults: function() {
return searchResults;
}
};
return service;
}]);
APIキーが公開されるため、実際の例を提供できません。