Надеюсь, это поможет вам.
import { Component } from '@angular/core';
import { HttpClient } from '@angular/common/http';
import { concatMap, switchMap, take, toArray, map } from 'rxjs/operators';
import { from } from 'rxjs';
@Component({
selector: 'my-app',
templateUrl: './app.component.html',
styleUrls: ['./app.component.css']
})
export class AppComponent {
name = 'Angular 6';
constructor(private http: HttpClient) { }
public url = "https://jsonplaceholder.typicode.com/todos";
public httpData: IPostWithComments[];
ngOnInit() {
this.http.get(this.url)
.pipe(
// Reveiced an array of posts
// Use "from" emit each value one by one
switchMap((posts: IPost[]) => from(posts)),
// Take(10) to avoid too many requests
take(10),
// For each post, fetch comments associated
concatMap((post: IPost) => this.http.get(`${this.url}/${post.id}/comments`)
.pipe(
// Only take the first five comments
map((comments: IComment[]) => comments.splice(0, 5))
),
// Use result selector function to add comments in the post object
(post: IPost, comments: IComment[]) => {
const postWithComments: IPostWithComments = {...post, comments};
return postWithComments;
}
),
// Aggregate all the posts in an array
toArray()
)
.subscribe((postsWithComments: IPostWithComments[]) => {
console.log(postsWithComments);
this.httpData = postsWithComments;
})
}
}
interface Kafein {
name:string;
address:string;
}
interface IPost {
completed: boolean;
id: number;
title: string;
userId: number;
}
interface IPostWithComments extends IPost {
comments: IComment[]
}
interface IComment {
body: string;
email: string;
id: number;
name: string;
postId: number;
}
Stackblitz