详解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 相关文章推荐
ajax异步刷新实现更新数据库
Dec 03 Javascript
网页广告中JS代码的信息监听示例
Apr 02 Javascript
jquery 选取方法都有哪些
May 18 Javascript
深入理解javascript作用域和闭包
Sep 23 Javascript
jQuery解决input超多的表单提交
Aug 10 Javascript
jQuery中cookie插件用法实例分析
Dec 04 Javascript
bootstrap+jQuery 实现下拉菜单中复选框全选和全不选效果
Jun 12 jQuery
jQuery 实现左右两侧菜单添加、移除功能
Jan 02 jQuery
快速对接payjq的个人微信支付接口过程解析
Aug 15 Javascript
vue 解决异步数据更新问题
Oct 29 Javascript
jQuery三组基本动画与自定义动画操作实例总结
May 09 jQuery
在vue中实现echarts随窗体变化
Jul 27 Javascript
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学习笔记 php中面向对象三大特性之一[封装性]的应用
2011/06/13 PHP
如何用PHP来实现一个动态Web服务器
2015/07/29 PHP
基于CI(CodeIgniter)框架实现购物车功能的方法
2018/04/09 PHP
PHP实现字符串的全排列详解
2019/04/24 PHP
laravel 修改.htaccess文件 重定向public的解决方法
2019/10/12 PHP
根据出生日期自动取得星座的js代码
2010/07/20 Javascript
Jquery ThickBox插件使用心得(不建议使用)
2010/09/08 Javascript
javascript中的self和this用法小结
2014/02/08 Javascript
jQuery截取指定长度字符串代码
2014/08/21 Javascript
轻松学习jQuery插件EasyUI EasyUI表单验证
2015/12/01 Javascript
JavaScript Promise 用法
2016/06/14 Javascript
实例解析jQuery中如何取消后续执行内容
2016/12/01 Javascript
使用ionic(选项卡栏tab) icon(图标) ionic上拉菜单(ActionSheet) 实现通讯录界面切换实例代码
2017/10/20 Javascript
javaScript字符串工具类StringUtils详解
2017/12/08 Javascript
全面分析JavaScript 继承
2019/05/30 Javascript
微信头像地址失效踩坑记附带解决方案
2019/09/23 Javascript
JS实现移动端可折叠导航菜单(现代都市风)
2020/07/07 Javascript
Vue+Java+Base64实现条码解析的示例
2020/09/23 Javascript
[47:43]Alliance vs KG 2019国际邀请赛小组赛 BO2 第一场 8.16
2019/08/18 DOTA
python中__slots__用法实例
2015/06/04 Python
Python Numpy数组扩展repeat和tile使用实例解析
2019/12/09 Python
Python多重继承之菱形继承的实例详解
2020/02/12 Python
使用Python将图片转正方形的两种方法实例代码详解
2020/04/29 Python
keras模型保存为tensorflow的二进制模型方式
2020/05/25 Python
django filter过滤器实现显示某个类型指定字段不同值方式
2020/07/16 Python
使用Python操作MySQL的小技巧
2020/09/10 Python
python 将html转换为pdf的几种方法
2020/12/29 Python
CSS3+js实现简单的时钟特效
2015/03/18 HTML / CSS
澳大利亚先进的皮肤和激光诊所购物网站:Soho Skincare
2018/10/15 全球购物
size?法国官网:英国伦敦的球鞋精品店
2020/03/15 全球购物
《巨人的花园》教学反思
2014/02/12 职场文书
户外活动策划方案
2014/03/12 职场文书
民族学专业大学生职业规划范文:清晰未来的构想
2014/09/20 职场文书
学校运动会报道稿
2014/09/23 职场文书
Redis 持久化 RDB 与 AOF的执行过程
2021/11/07 Redis
css中有哪些方式可以隐藏页面元素及区别
2022/06/16 HTML / CSS