首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >Angular Multiple subscriptions然后执行操作

Angular Multiple subscriptions然后执行操作
EN

Stack Overflow用户
提问于 2019-05-30 21:41:14
回答 2查看 149关注 0票数 2

我有一个使用订阅从API请求数据的函数。我正在尝试重写它,以便在所有API调用完成时返回一个布尔值。有没有更好的方法来写这篇文章?

我当前的代码:

代码语言:javascript
复制
public res1=null;
public res2=null;

getData(){
 this.svc.getData1().subscribe(x={this.res1=x;})
 this.svc.getData2().subscribe(x={this.res2=x;})
}

我正在考虑尝试创建一个监听对嵌套订阅的更改的可观察性:(不是测试代码!)

代码语言:javascript
复制
getData(): Observable<boolean>{
 this.svc.getData1().subscribe(x=>{
   this.res1=x;
   this.svc.getData2().subscribe(x=>{this.res2=x; 
     return true;
   })
 })
)

}

EN

回答 2

Stack Overflow用户

发布于 2019-05-30 21:50:10

其中一种方法是使用combineLatest。当所有可观察对象都发出一个值时,合并最新值。

代码语言:javascript
复制
combineLatest(observeable1$, observable2$).subscribe(
  // when both have submitted a value. return what you like.
);

如果你的可观察对象只会解析一次。您也可以使用forkJoin。它类似于promise.All

票数 1
EN

Stack Overflow用户

发布于 2019-05-30 22:24:00

您可以使用合并运算符来合并可观察对象并并行订阅它们。

代码语言:javascript
复制
 getData(): Observable<boolean>{
    let isCompleted: Observable<boolean>;
    merge(this.svc.getData1(), this.svc.getData2()).subscribe(
      (val) => {console.log(val) },
    (err) => { console.log(err) },
    ()=>{isCompleted = of (true); });
    return isCompleted;
  }
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/56379485

复制
相关文章

相似问题

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