AngularJS中的$http缓存以及处理多个$http请求

 

在AngularJS的实际项目中,经常需要处理多个$http请求,每个$http请求返回一个promise,我们可以把多个promise放到$q.all()方法接受的一个数组实参中去。

■ 处理多个$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(){
                ....
            })
        }
    })

 

■ $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来清除缓存

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值