javascript - Rxjs/reactor limit operator 等效于 ajax 请求

标签 javascript ajax rxjs reactor

我想要实现的是同时执行许多 ajax 请求(从 10 到 1000+ 不等),但事件请求的数量限制为 5(就请求的执行而言,就像一个 FIFO 队列)。

例如我们有一个包含 100 个 http 地址的数组,我们想要获取前 5 个并为每个地址执行 GET 请求,如果这五个请求中的任何一个结束则另一个地址应该进入队列并执行其 GET 请求直到所有100 个地址发出请求并完成。

react 堆库有limitRequest符合我描述的运算符

我的问题是如何使用 rxjs 实现类似的行为?

我尝试使用缓冲区运算符,但它每完成 5 个请求就会发出结果,我想要的是在请求完成后立即发出结果。

我创建了一个 stackblitz

尝试对此进行实验

最佳答案

您只需使用两个 mergeMap 即可完成所有这些工作。 mergeMap 运算符接受第二个参数,即并发 Observable 的数量。第一个 mergeMap 将用于解压来自服务器的 URL 数组,第二个将保持 5 个并发请求:

根据您的 stackblitz 演示(顺便感谢您提供演示),您可以将所有这些放入单个 RxJS 链中。

from(axios.get("https://jsonplaceholder.typicode.com/photos")).pipe(
  mergeMap(response => response.data // Unwrap the array of URLs into single emissions
    .filter(x => x.albumId === 100)
    .map(x => x.url)
  ),
  mergeMap(url => of(url).pipe(delay(1000 * Math.random())), 5), // Mock additional requests with of() and delay()
).subscribe(console.log);

您更新的演示:https://stackblitz.com/edit/photo-dls-pb27pn?file=index.js

关于javascript - Rxjs/reactor limit operator 等效于 ajax 请求,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/53516160/

相关文章:

javascript - 在 Javascript/JQuery 中,如何像 Twitter 那样替换以 '@' 符号开头的字符串中的任何单词?

php - 使用 AJAX 时,如何在同一个 PHP 文件中放置选择和插入代码?

javascript - 自动填充多个选择框在 Internet Explorer 中选择了第一个选项

angular - 捕获错误后如何忽略错误并在rxjs forkJoin中执行最终结果?

javascript - rxjs switchmap observable,为最终保存变量

javascript - 使用ngrx效果时避免多次请求

javascript - React Native Swift 模块中的回调函数

javascript - 子元素的边距

javascript - PHP 中的三重引号?

jquery - ajax 成功后循环 JSON 响应