首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >避免嵌套观测( mergeMap表示完成)

避免嵌套观测( mergeMap表示完成)
EN

Stack Overflow用户
提问于 2021-11-11 15:52:37
回答 1查看 39关注 0票数 0

获得了这个伪代码,用于一个刮取服务,该服务首先探索分页urls,然后是刮过的“父”网站上的子页url。

代码语言:javascript
复制
const pagination = [["url-1", "url-2", "url-3", "url-4"], ["url-5"]];
const timeInterval = 2;

sendRequestsInIntervals(pagination, timeInterval )
  .pipe()
  .subscribe({
    next(x) {
      console.log(x);
    },
    error(err) {
      console.error(err);
    },
    complete() {
      console.log("done");
      sendRequestsInIntervals(resDataArray, timeInterval ).subscribe({
        next(x) {
          console.log(x);
        },
      });
    },
  });

我想避免嵌套,因为这是一种不正确的使用可观察的方法。

有没有办法把它转换成这样的东西:

代码语言:javascript
复制
sendRequestsInIntervals(pagination, timeInterval )
  .pipe(
    waitUntilCompletes()
    mergeMap((resDataArray) => {
      return sendRequestsInIntervals(resDataArray, timeInterval );
    })
  )
  .subscribe({
    next(x) {
      console.log(x);
    },
    error(err) {
      console.error(err);
    },
    complete() {
      console.log("done");
    },
  });

添加了一个名为waitUntilCompletes()的伪函数

在rxJS中是否存在这样一种情况,即在运行之前等待mergeMap中的可观测性,直到之前的可观测性完成为止?

EN

回答 1

Stack Overflow用户

发布于 2021-11-11 15:58:25

last操作符将忽略所有排放,直到完成最后一项:

代码语言:javascript
复制
sendRequestsInIntervals(pagination, timeInterval )
  .pipe(
    last(),
    mergeMap((resDataArray) => { // resDataArray is only the final emitted value from sendRequestsInIntervals() 
      return sendRequestsInIntervals(resDataArray, timeInterval );
    })
  )
  .subscribe({
    next(x) {
      console.log(x);
    },
    error(err) {
      console.error(err);
    },
    complete() {
      console.log("done");
    },
  });

或者,您可以使用reduce收集排放并在完成后排放:

代码语言:javascript
复制
sendRequestsInIntervals(pagination, timeInterval )
  .pipe(
    // this will gather all outter emissions into an array and emit once outter completes
    reduce((acc, val) => acc.concat(val), []),
    mergeMap((resDataArray) => { // resDataArray is all values emitted from sendRequestsInIntervals() in an array
      return sendRequestsInIntervals(resDataArray, timeInterval );
    })
  )
  .subscribe({
    next(x) {
      console.log(x);
    },
    error(err) {
      console.error(err);
    },
    complete() {
      console.log("done");
    },
  });
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/69931212

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档