[AngularJS] $http cache

By default your HTTP requests with the $https service in Angular are not cached. By setting some options, you can turn caching on.

 

/**
 * Created by Answer1215 on 12/15/2014.
 */


angular.module('app', ['ngMaterial'])
    .controller('MainCtrl', function(BookmarksService, BookmarksCacheFactory) {
        var mainCtrl = this;
        mainCtrl.bookmarks = [];

        mainCtrl.getBookmarks = function() {
            BookmarksService.getBookmarks().then(function(response) {
                mainCtrl.bookmarks = response.data;
            });
        }

        mainCtrl.removeCache = function() {
            BookmarksCacheFactory.remove('./data/bookmarks.json');
        }
    })


    .service('BookmarksService', function($http, BookmarksCacheFactory) {
        var BookmarksService = {};

        BookmarksService.getBookmarks = function() {
            return $http.get('./data/bookmarks.json', {cache: BookmarksCacheFactory});
        }

        return BookmarksService;
    })


    .factory('BookmarksCacheFactory', function($cacheFactory) {
        return $cacheFactory('bookmarks');
    });

 

<!DOCTYPE html>
<html>
<head lang="en">
    <meta charset="UTF-8">
    <title></title>
    <link rel="stylesheet" href="//rawgit.com/angular/bower-material/master/angular-material.css">
    <link rel="stylesheet" href="./bower_components/angular-material/themes/indigo-theme.css">
    <link rel="stylesheet" href="./bower_components/angular-material/themes/teal-theme.css">
</head>
<body ng-app="app" ng-controller="MainCtrl as main" >
    <md-content>
        <section  layout="column" layout-align="start start">
            <div ng-repeat="b in main.bookmarks">{{b.title}}</div>
        </section>
    </md-content>
    <md-button ng-click="main.getBookmarks()" class="md-primary md-raised" md-theme="indigo">Load Bookmarks</md-button>
    <md-button ng-click="main.removeCache()" class="md-primary md-raised" md-theme="teal">Clear cache</md-button>
    <!-- Angular Material Dependencies -->
    <script src="//cdn.jsdelivr.net/hammerjs/2.0.4/hammer.js"></script>
    <script src="//ajax.googleapis.com/ajax/libs/angularjs/1.3.6/angular.js"></script>
    <script src="//ajax.googleapis.com/ajax/libs/angularjs/1.3.6/angular-animate.js"></script>
    <script src="//ajax.googleapis.com/ajax/libs/angularjs/1.3.6/angular-aria.js"></script>

    <!-- Angular Material Javascript using RawGit to load directly from `bower-material/master` -->
    <script src="//rawgit.com/angular/bower-material/master/angular-material.js"></script>
    <script src="app.js"></script>
</body>
</html>

 

"Load bookmarks" only work for the first time clicking the button and load the data.

After click "clear cache", then will load data again.

转载于:https://www.cnblogs.com/Answer1215/p/4166163.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值