SwitchMap Angular /
Я обновил свой угловой до ng7. Я работаю над проектом, где у меня 3 http-вызова, которые зависят друг от друга, поэтому я решил использовать switchMap. Моя проблема в том, что способ, которым я написал switchMap прежде, не работает. Так обычно пишут мои
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?
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)
}
}
));
}
1 ответ
Это должно сделать это:
createCompWithGroup(competitionName: string) {
return this.apiService.createACompetition(competitionName).pipe(
switchMap(data => this
.addSecurityGroup(competitionName, `${data.cateogry.id}-${data.cateogry.slug}`)
)
)
}
subscribe
Параметр будет ответом addSecurityGroup
запрос.