2016-07-05 112 views
8

我試圖禁用我的AngularJS應用的緩存,但它不與下面的代碼工作:

$http.get("myurl",{cache:false}) 

當我使用"myurl&random="+Math.random(),緩存爲禁用;但是,我想要一個不同的方法。

+0

這已經回答了[這裏](http://stackoverflow.com/questions/16098430/angular-ie-caching-issue-for-http)。 – user6408463

+0

可能重複[Angular IE緩存問題$ http](https://stackoverflow.com/questions/16098430/angular-ie-caching-issue-for-http) –

回答

18

這已經回答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'; 
}]); 
+0

Coool!解決了我的問題..謝謝你們! – Saxophonist

+0

我建議不要使用Pragma。這不是一個標準(顯然),並可能會導致Cross Origin請求出現問題。剛剛完成了與朋友的2小時調試會話,瞭解這是問題的原因。 –

1

嘗試這樣

$state(' 'app.name', { 
url: '/name', 
cache: false, 
controller:'MainCtrl', 
templateUrl:'templates/name.html' 
}) 
+0

不知道這個答案是如何應用的。問題是關於http get。不是模板。 – tatmanblue

0
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

1

這裏是我做的,只是將其更改爲

$http.get("myurl",{headers:{'Cache-Control': 'no-cache'}})