最近项目在做IE10,11的兼容性测试,发现$http的get方法只会下发一次请求,经过查询,才得知是因为IE强制缓存了get方法获取的数据。
解决方法一:判断是是否是ie,是ie则禁用缓存。如果不判断,在谷歌中会报错。
var explorer = window.navigator.userAgent ; //ie,如果为ie,则强制清除缓存。规避ie的get方法强行缓存的坑 if ((explorer.toLowerCase().indexOf("trident") > -1 && explorer.indexOf("rv") > -1) || explorer.indexOf("MSIE")>=1) { 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'; }
解决方法二:在每个请求后面拼接当前时间戳。
?timestamp='+new Date().getTime()