Is it good to call subscribe inside subscribe?(在SUBSCRIBE内呼叫SUBSCRIBE好吗?)
本文介绍了在SUBSCRIBE内呼叫SUBSCRIBE好吗?的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!
问题描述
我需要从三个不同的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.
});
..。诸若此类。有许多运算符可以组成可观测对象,以覆盖许多不同的方案。
这篇关于在SUBSCRIBE内呼叫SUBSCRIBE好吗?的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持编程学习网!
织梦狗教程
本文标题为:在SUBSCRIBE内呼叫SUBSCRIBE好吗?
基础教程推荐
猜你喜欢
- Fabric JS绘制具有活动形状的多边形 2022-01-01
- fetch 是否支持原生多文件上传? 2022-01-01
- 即使用户允许,Gmail 也会隐藏外部电子邮件图片 2022-01-01
- 检查 HTML5 拖放文件类型 2022-01-01
- Bootstrap 模态出现在背景下 2022-01-01
- 在 contenteditable 中精确拖放 2022-01-01
- 原生拖动事件后如何获取 mouseup 事件? 2022-01-01
- npm start 错误与 create-react-app 2022-01-01
- 如何添加到目前为止的天数? 2022-01-01
- Bokeh Div文本对齐 2022-01-01
