首頁 >web前端 >js教程 >詳解AngularJS中$http快取以及處理多個$http請求的方法_AngularJS

詳解AngularJS中$http快取以及處理多個$http請求的方法_AngularJS

WBOY
WBOY原創
2016-05-16 15:16:091558瀏覽

$http 是 AngularJS 中的一個核心服務,用於讀取遠端伺服器的資料。在AngularJS的實際專案中,常常需要處理多個$http請求,每個$http請求回傳一個promise,我們可以把多個promise放到$q.all()方法接受的一個陣列實參中去。

1.處理多個$http請求

angular.module('app',[])
.controller('AppCtrl', function AppCtrl(myService){
var app = this;
myService.getAll().then(function(info){
app.myInfo = info;
})
})
.service('myService', function MyService($http, $q){
var myService = this;
user = 'https://api...',
repos = '',
events = '';
myService.getData = function getData(){
return $http.get(user).then(function(userData){
return {
name:userData.data.name,
url:userData.data.url,
repoCount: userData.data.count
}
})
};
myService.getUserRepos = function getUserRepos(){
return $http.get(repos).then(function(response){
return _.map(response.data, function(item){
return {
name: item.name,
description:item.description,
starts: item.startCount
}
})
})
}
myService.getUserEvents = function getUserEvents(){
...
}
myService.getAll = function(){
var userPromise = myService.getData(),
userEventsPromise = myService.getUserRepos(),
userReposPromise = myService.getUserRepos();
return $q.all([userPromise, userEventsPromise, userReposPromise]).then(function(){
....
})
}
})

2.$http請求快取

$http的get方法第二個形參接受一個對象,該對象的cache字段可以接受一個bool類型實現緩存,即{cache:true},也可以​​接受一個服務。

透過factory方式建立一個服務,並把該服務注入到controller中去。

angular.module('app',[])
.factory("myCache", function($cacheFactory){
return $cacheFactory("me");
})
.controller("AppCtrl", function($http, myCache){
var app = this;
app.load = function(){
$http.get("apiurl",{cache:myCache})
.success(function(data){
app.data = data;
})
}
app.clearCache = function(){
myCache.remove("apiurl");
}
})

小編總結:

● 實際上,實作快取機制的是$cacheFactory
● 透過{cache:myCache}把快取機制放在目前請求
● $cacheFactory把請求api當成key,所以清楚快取的時候,也是根據這個key來清除快取

以上所述是小編給大家分享的AngularJS中$http快取以及處理多個$http請求的方法,希望對大家有幫助。

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn