详解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 相关文章推荐
javascript this用法小结
Dec 19 Javascript
jQuery点击后一组图片左右滑动的实现代码
Aug 16 Javascript
jquery将一个表单序列化为一个对象的方法
Jan 03 Javascript
jquery实现鼠标滑过小图时显示大图的方法
Jan 14 Javascript
JavaScript 总结几个提高性能知识点(推荐)
Feb 20 Javascript
利用JavaScript的%做隔行换色的实例
Nov 25 Javascript
Bootstrap实现可折叠分组侧边导航菜单
Mar 07 Javascript
解决element UI 自定义传参的问题
Aug 22 Javascript
如何使用 vue + d3 画一棵树
Dec 03 Javascript
JavaScript使用小插件实现倒计时的方法讲解
Mar 11 Javascript
vue-cli 3 全局过滤器的实例代码详解
Jun 03 Javascript
vue-router跳转时打开新页面的两种方法
Jul 29 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
一个基于PDO的数据库操作类(新) 一个PDO事务实例
2011/07/03 PHP
php后退一页表单内容保存实现方法
2012/06/17 PHP
thinkphp实现图片上传功能分享
2014/03/04 PHP
PHP simplexml_load_file()函数讲解
2019/02/03 PHP
javascript学习之闭包分析
2010/12/02 Javascript
深入分析js的冒泡事件
2014/12/05 Javascript
值得分享的轻量级Bootstrap Table表格插件
2016/05/30 Javascript
使用jQuery加载html页面到指定的div实现方法
2016/07/13 Javascript
Node.js Express 框架 POST方法详解
2017/01/23 Javascript
Vue.js 插件开发详解
2017/03/29 Javascript
详解Angular结合zTree异步加载节点数据
2018/01/20 Javascript
vue-cli 打包使用history模式的后端配置实例
2018/09/20 Javascript
JavaScript学习笔记之DOM操作实例分析
2019/01/08 Javascript
nodejs中request库使用HTTPS代理的方法
2019/04/30 NodeJs
如何利用vue实现波谱拟合详解
2020/11/05 Javascript
Python学习之asyncore模块用法实例教程
2014/09/29 Python
python 在屏幕上逐字显示一行字的实例
2018/12/24 Python
了解一下python内建模块collections
2020/09/07 Python
纯CSS实现聊天框小尖角、气泡效果
2014/04/04 HTML / CSS
英国女性时尚鞋类的潮流制造者:Koi Footwear
2018/10/19 全球购物
文员自我评价怎么写
2013/09/19 职场文书
销售副总经理岗位职责
2013/12/11 职场文书
社区学习十八大感想
2014/01/22 职场文书
商务日语专业毕业生自荐信
2014/03/27 职场文书
5s推行计划书
2014/05/06 职场文书
学雷锋标语
2014/06/25 职场文书
IT工程师岗位职责
2014/07/04 职场文书
给妈妈洗脚活动方案
2014/08/16 职场文书
初中优秀教师事迹材料
2014/08/18 职场文书
幼儿教师暑期培训方案
2014/08/27 职场文书
2014年体育部工作总结
2014/11/13 职场文书
婚庆司仪开场白
2015/05/29 职场文书
幼师自荐信范文(2016推荐篇)
2016/01/28 职场文书
Python办公自动化之Excel(中)
2021/05/24 Python
Python自动化爬取天眼查数据的实现
2021/06/15 Python
MySQL Server 层四个日志
2022/03/31 MySQL