详解AngularJS中$http缓存以及处理多个$http请求的方法


Posted in Javascript onFebruary 06, 2016

$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请求的方法,希望对大家有所帮助。

Javascript 相关文章推荐
jquery查找tr td 示例模拟
May 08 Javascript
jquery小火箭返回顶部代码分享
Aug 19 Javascript
JS与jQuery遍历Table所有单元格内容的方法
Dec 07 Javascript
Vue.js第二天学习笔记(vue-router)
Dec 01 Javascript
Vue中render方法的使用详解
Jan 26 Javascript
vue弹窗插件实战代码
Sep 08 Javascript
微信小程序实现页面跳转传递参数(实体,对象)
Aug 12 Javascript
如何阻止小程序遮罩层下方图层滚动
Sep 05 Javascript
基于iview-admin实现动态路由的示例代码
Oct 02 Javascript
在js文件中引入(调用)另一个js文件的三种方法
Sep 11 Javascript
解决Ant Design Modal内嵌Form表单initialValue值不动态更新问题
Oct 29 Javascript
jQuery实现影院选座订座效果
Apr 13 jQuery
JavaScript中数组添加值和访问值常见问题
Feb 06 #Javascript
详解Angularjs filter过滤器
Feb 06 #Javascript
Angularjs中如何使用filterFilter函数过滤
Feb 06 #Javascript
浅析Javascript匿名函数与自执行函数
Feb 06 #Javascript
JS通过Cookie判断页面是否为首次打开
Feb 05 #Javascript
JavaScript判断图片是否已经加载完毕的方法汇总
Feb 05 #Javascript
jquery实现的判断倒计时是否结束代码
Feb 05 #Javascript
You might like
php魔术变量用法实例详解
2014/11/13 PHP
PHP基于自定义函数实现的汉字转拼音功能实例
2017/09/30 PHP
PHP pthreads v3下同步处理synchronized用法示例
2020/02/21 PHP
OfflineSave离线保存代码再次发布使用说明
2007/05/23 Javascript
JavaScript 浮点数运算 精度问题
2009/10/06 Javascript
js DOM 元素ID就是全局变量
2012/09/20 Javascript
js中onload与onunload的使用示例
2013/08/25 Javascript
javascript通过navigator.userAgent识别各种浏览器
2013/10/25 Javascript
PHP PDO操作总结
2014/11/17 Javascript
AngularJS iframe跨域打开内容时报错误的解决办法
2015/01/26 Javascript
JavaScript基础教程——入门必看篇
2016/05/20 Javascript
JavaScript实现网页头部进度条刷新
2017/04/16 Javascript
vue的Virtual Dom实现snabbdom解密
2017/05/03 Javascript
JS 调试中常见的报错问题解决方法
2017/05/20 Javascript
使用vue和datatables进行表格的服务器端分页实例代码
2017/06/07 Javascript
基于vue-ssr服务端渲染入门详解
2018/01/08 Javascript
基于React+Redux的SSR实现方法
2018/07/03 Javascript
JS返回页面时自动回滚到历史浏览位置
2018/09/26 Javascript
如何在基于vue-cli的项目自定义打包环境
2018/11/10 Javascript
Nodejs中的require函数的具体使用方法
2019/04/02 NodeJs
ES6入门教程之let、const的使用方法
2019/04/13 Javascript
微信小程序自定义tabBar在uni-app的适配详解
2019/09/30 Javascript
使用JS监听键盘按下事件(keydown event)
2019/11/07 Javascript
微信小程序12行js代码自己写个滑块功能(推荐)
2020/07/15 Javascript
[05:08]第一届“网鱼杯”DOTA2比赛精彩集锦
2014/09/05 DOTA
[51:43]OG vs LGD 2018国际邀请赛淘汰赛BO3 第五场 8.26
2018/08/30 DOTA
Django Admin中增加导出CSV功能过程解析
2019/09/04 Python
python多进程并发demo实例解析
2019/12/13 Python
python 中的[:-1]和[::-1]的具体使用
2020/02/13 Python
Win 10下Anaconda虚拟环境的教程
2020/05/18 Python
python中re模块知识点总结
2021/01/17 Python
一款纯css3实现的漂亮的404页面的实例教程
2014/11/27 HTML / CSS
外语系毕业生自荐信范文
2013/12/16 职场文书
房屋租赁授权委托书范本
2014/09/20 职场文书
干部作风建设工作总结
2014/10/29 职场文书
2016中秋晚会开幕词
2016/03/03 职场文书