angularjs – 方法发布时的$http服务缓存
发布时间:2020-12-17 06:48:51 所属栏目:安全 来源:网络整理
导读:当我将$http设置为缓存请求时,我仍然看到从浏览器网络发送到服务器的重复请求(具有相同的URL和相同的数据), $http.post(url,data,{cache:true} ).success(function(response) { 我有以下问题: 这是正确的行为吗? 我们可以缓存帖子请求吗? 这是正确的方法,
当我将$http设置为缓存请求时,我仍然看到从浏览器网络发送到服务器的重复请求(具有相同的URL和相同的数据),
$http.post(url,data,{cache:true} ).success(function(response) { 我有以下问题: >这是正确的行为吗? 解决方法
从
docs:
如果要缓存POST请求,则必须手动执行.您需要创建一个缓存响应的服务/工厂,并在$http之前充当图层.您可以使用$cacheFactory或仅使用普通对象. function cacheService($http,$q){ var cache = {}; this.callSomething = function(postData){ let deferred = $q.defer(); let hash = angular.toJson(postData); if(cache[hash]){ deferred.resolve(cache[hash]); } else { $http.post('path/to/resource',postData).then(function(response){ cache[hash] = response; deferred.resolve(response); }); } return deferred.promise; } } 这是一个简单的例子,你当然可以使用相同的原理并制作一个更通用的服务,它接受一个URL,postData和一个缓存对象,并返回一个执行请求并缓存它的函数. (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |