javascript - 在subscribe里面调用subscribe好不好?

标签 javascript functional-programming rxjs observable

我需要从三个不同的 API 向一个函数传递三个数据:

this.service.service1().subscribe( res1 => {
  this.service.service1().subscribe( res2 => {
    this.service.service1().subscribe( res3 => {
      this.funcA(res1, res2, res3);
  });
  });
});

在订阅内订阅是一种好习惯吗?

最佳答案

正确的方法是以某种方式组合各种可观察对象,然后订阅整个流程——如何组合它们将取决于您的具体要求。

如果你能同时完成它们:

forkJoin(
  this.service.service1(), this.service.service2(), this.service.service3()
).subscribe((res) => {
  this.funcA(res[0], res[1], res[2]);
});

如果每个都依赖于前一个的结果,您可以使用mergeMap(以前称为flatMap)或switchMap:

this.service.service1().pipe(
  mergeMap((res1) => this.service.service2(res1)),
  mergeMap((res2) => this.service.service3(res2))
).subscribe((res3) => {
  // Do something with res3.
});

...等等。有许多运算符可以组合可观察对象以涵盖许多不同的场景。

关于javascript - 在subscribe里面调用subscribe好不好?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/52317494/

相关文章:

javascript - 加载大量数据/内容时,网站滚动速度很慢

javascript - 获取显示字段中的值 Ext JS 5

haskell - 如何让 Haskell 计算正确的多态类型?

angular - 在 fromEvent resize observable 中添加初始值

javascript - Angular 2 rxjs 嵌套 Observables

rxjs - 使用 .map 转换 Observable

javascript - ng-show 不只在加载时运行动画

functional-programming - 用无限流替换符号表达式

python - 对于学习 Python 函数式编程,推荐哪些好的家庭作业式教程?

javascript - Jquery 每次替换innerHtml