我試圖禁用我的AngularJS應用的緩存,但它不與下面的代碼工作:
$http.get("myurl",{cache:false})
當我使用"myurl&random="+Math.random()
,緩存爲禁用;但是,我想要一個不同的方法。
我試圖禁用我的AngularJS應用的緩存,但它不與下面的代碼工作:
$http.get("myurl",{cache:false})
當我使用"myurl&random="+Math.random()
,緩存爲禁用;但是,我想要一個不同的方法。
這已經回答here。
從鏈接粘貼代碼片段供您參考。
myModule.config(['$httpProvider', function($httpProvider) {
//initialize get if not there
if (!$httpProvider.defaults.headers.get) {
$httpProvider.defaults.headers.get = {};
}
// Answer edited to include suggestions from comments
// because previous version of code introduced browser-related errors
//disable IE ajax request caching
$httpProvider.defaults.headers.get['If-Modified-Since'] = 'Mon, 26 Jul 1997 05:00:00 GMT';
// extra
$httpProvider.defaults.headers.get['Cache-Control'] = 'no-cache';
$httpProvider.defaults.headers.get['Pragma'] = 'no-cache';
}]);
Coool!解決了我的問題..謝謝你們! – Saxophonist
我建議不要使用Pragma。這不是一個標準(顯然),並可能會導致Cross Origin請求出現問題。剛剛完成了與朋友的2小時調試會話,瞭解這是問題的原因。 –
嘗試這樣
$state(' 'app.name', {
url: '/name',
cache: false,
controller:'MainCtrl',
templateUrl:'templates/name.html'
})
不知道這個答案是如何應用的。問題是關於http get。不是模板。 – tatmanblue
myApp.config(function ($routeProvider) {
$routeProvider.
when('/', {controller: 'MyCtrl', templateUrl: '/eshop/myConfig'})
})
.controller('MyCtrl', function ($scope, $templateCache) {
$templateCache.remove('/eshop/myConfig');
// or
$templateCache.removeAll();
});
我沒有測試它。我發現了一些在這個url.Have看看這個 Angularjs - how to clear $routeProvider's caches of templateUrl
這裏是我做的,只是將其更改爲
$http.get("myurl",{headers:{'Cache-Control': 'no-cache'}})
這已經回答了[這裏](http://stackoverflow.com/questions/16098430/angular-ie-caching-issue-for-http)。 – user6408463
可能重複[Angular IE緩存問題$ http](https://stackoverflow.com/questions/16098430/angular-ie-caching-issue-for-http) –