如何解决angularJS route 缓存问题

如何解决angularJS route 缓存问题


白猪掌柜的
浏览 557回答 2
2回答

万千封印

把下面的代码加上试试var app = angular.module('phonecat', ['ngRoute']);app.config(['$routeProvider', '$httpProvider',function($routeProvider, $httpProvider) {if (!$httpProvider.defaults.headers.get) {$httpProvider.defaults.headers.get = {};}$httpProvider.defaults.headers.common["X-Requested-With"] = 'XMLHttpRequest';$httpProvider.defaults.headers.get['Cache-Control'] = 'no-cache';$httpProvider.defaults.headers.get['Pragma'] = 'no-cache';$routeProvider.when('/phones', {templateUrl: 'phone-list.html',controller: PhoneListCtrl}).when('/phones/:phoneId', {templateUrl: 'phone-detail.html',controller: PhoneDetailCtrl}).otherwise({redirectTo: '/phones'});}]);

小怪兽爱吃肉

如果用AngularJs在IE下发出GET请求从后台服务取完Json数据再绑定到页面上显示的话,你可能会发现就算数据更新了,IE还是会显示原来的结果。实际上这时候IE的确是缓存了hashtag,没有再次去做Http GET请求最新的数据。最直接的办法是在后台撸掉OutputCache,但这种做法并不推荐,需要改每一处被Angular调用的地方,代价太大。这种问题应该在前端解决最好。研究了一会儿总结了最有效的解决方法,并不需要改后台代码了。在你的app config里撸一个$httpProvider进去,比如像我这样,和路由可以配在一起,当然分开配也没问题。
打开App,查看更多内容
随时随地看视频慕课网APP

相关分类

AngularJS