当前位置: 首页 > 面试题库 >

在Angular中阻止多个$ http请求。有没有更好的办法?

师承弼
2023-03-14
问题内容

我已经构建了一种通过$ http返回资源的复杂方法。

该方法返回一个Promise,然后检查资源是否存在我的本地缓存。如果这样做,它将返回缓存的资源,否则,将发出$
http请求。在资源被缓存后,这种方法效果很好,但是在整个应用程序中,我有多种功能正在按此方法加载,并且每个函数都会发出http请求,因为资源尚未返回和缓存。

我想出了一个简单的检查方法来解决此问题,但我觉得应该有一个更好的方法。我添加了一个布尔值,如果该方法处于获取资源的中间,则将其设置为true;如果是,则使用半秒超时来解析该方法,以给请求时间来解决。代码如下。

那么,有没有更好的方法?

   var schools = [];
   var loadingSchools = false;

   function getAllSchools(forceUpdate) {
        return $q(function (resolve, reject) {
            if(loadingSchools) resolve($timeout(getAllSchools, 500));

            else{

                loadingSchools = true;

                if (schools.length && !forceUpdate) {
                    loadingSchools = false;
                    resolve(schools);
                    return;
                }

                console.log('$http: Getting All Schools - schoolService.js');

                $http.get(API_PATH + 'schools_GetAll', {cache:true})
                .success(function(result) {
                    schools = result;
                    loadingSchools = false;
                    resolve(schools);
                })
                .error(function(error) {
                    schools = [];
                    loadingSchools = false;
                    reject(error);
                });
            }
        });
    }

问题答案:

首先,我认为没有必要将其包装HttpPromise到另一个承诺中。在不赞成使用success/error方法的情况下,您应该仅依靠该方法,并将当作常规承诺。then()``HttpPromise

为了确保只发送一次请求,您实际上可以跟踪HttpPromise创建的第一个请求,并在随后的函数调用中返回相同的promise。

这是一项服务,它将接受API端点作为参数,并确保仅向该API发送一个请求。

app.factory('$httpOnce', [ '$http', '$cacheFactory',
  function ($http, $cacheFactory) {
    var cache = $cacheFactory('$httpOnce');

    return function $httpOnce(url, options) {
      return cache.get(url) || cache.put(url, $http.get(url, options)
        .then(function (response) {
          return response.data;
        }));
    };
  }
]);

用法

function log(data) {
  console.log(data);
}

// issues an HTTP request
$httpOnce('https://api.github.com/').then(log);
// does not issue an HTTP request, returns the same promise as above
$httpOnce('https://api.github.com/').then(log);

// ...
// HTTP request completes somewhere, both promises above are resolved
// ...

setTimeout(function () {
  // immediately resolved
  $httpOnce('https://api.github.com/').then(log);
}, 5000);

这是一个演示。您可以在开发工具中看到仅发出一个请求。



 类似资料:
  • 问题内容: 这个想法是在某些情况下从另一个来源获取数据,所以我有这个存根: 失败了 [$ injector:cdep]找到循环依赖项:拦截器<-$ http 还尝试注入$ injector并使用它获取$ http,结果相同。有任何想法吗? .config就是声明: 问题答案: 注入到: 用它来获取回调函数中返回的对象。 这是一个例子

  • 例如,分区有1-10的偏移量。我只想从3-8消费。在消耗了第8条消息后,程序应该退出。

  • 我在Pivotal Cloud foundry上有一个Web API;其中包括它的招摇文档。 然而,每当我试图测试任何应用编程接口endpoint时,斯瓦格都会在请求网址中在主机后添加一个端口号: port,这阻止了与应用编程接口endpoint的连接,因此没有数据返回。出于某种原因,在枢轴上托管的应用编程接口对端口号不满意;相反,路由网址似乎工作正常。 我托管一个ASP. NET Web API

  • 问题内容: 请先检查代码 app.js route.js home-controller.js stats-controller.js api.js 当我从家搬到stats时,API再次发送http请求,我有很多这样的http调用,我只粘贴了几行代码。 我需要做的是 取消 在routechangestart或成功时中止所有未决的http请求的操作 或任何其他方式来实现相同? 问题答案: 为此,我整

  • 我有一个枚举类来存储一些像这样的分类值。 每种类型都有pydantic模型。例如: 我有这样的字典: 我有一个FastAPI路由,用户需要输入字段类型名称作为字符串(从FastAPI文档中的下拉列表),并根据选择的类型提供类型属性。如果用户选择type=“images”,则会提供相应的pydantic模型“ImageModel”供用户填写,以此类推。 选择类型名称后,有没有办法产生对应的pydan

  • 在web上,我只找到了一种停止迭代方法的方法。通过使用limit()函数。但这会迭代一个具体的循环数。我想用它来停止一个谓词。 有没有办法用Streams做到这一点? 更新1:使用Java 8