首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >switchMap Angular /

switchMap Angular /
EN

Stack Overflow用户
提问于 2018-10-25 18:14:14
回答 1查看 267关注 0票数 1

我把我的angular升级到了ng7。我正在做一个项目,其中我有3个http调用,它们是相互依赖的,所以我选择使用switchMap。我的问题是,我以前编写switchMap的方式不起作用。这通常是我写它的方式

代码语言:javascript
复制
DeleteConfirm(id: number, $event) {
console.log('product');
this.productService.deleteProductById(
  id).switchMap(productDeleted => this.productService.getProducts())
  .subscribe(
    products => {
      this.products = products;
      this.confirmDelete = false;
    }, error2 => {}
  );
$event.stopPropagation();

}

下面的方法就是我现在正在使用的方法。对如何使用switchMap有什么建议吗?

代码语言:javascript
复制
createCompWithGroup(competitionName: string) {

return this.apiService.createACompetition(competitionName)
  .pipe(switchMap(data => {
    const competition = data['category'];
    const competitionSlug = competition.id + '-' + competition.slug;
     this.createSecurityGroup(competitionSlug).subscribe( data =>{
   return   this.addSecurityGroup(competitionName, competitionSlug)
     }
  }
  ));

}

EN

回答 1

Stack Overflow用户

发布于 2018-10-25 18:27:24

这应该可以做到:

代码语言:javascript
复制
createCompWithGroup(competitionName: string) {
  return this.apiService.createACompetition(competitionName).pipe(
    switchMap(data => this
      .addSecurityGroup(competitionName, `${data.cateogry.id}-${data.cateogry.slug}`)
    )
  )
}

subscribe参数将是addSecurityGroup请求的响应。

票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/52986815

复制
相关文章

相似问题

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