[英]Array of observables angular rxjs
我有以下代码:
export class GetPersonsService {
url="https://swapi.co/api/people/";
personsObservables;
headers: HttpHeaders = new HttpHeaders()
.set('Accept', 'application/json');
constructor(private http:HttpClient) { }
getPerson(personIndex){
return this.http.get<Person>(`${this.url}${personIndex}`,{headers:this.headers});
}
getPersons(){
for(let i=0;i<10;i++){
this.personsObservables.push(this.getPerson(i));
}
console.log(this.personsObservables);
return forkJoin(this.personsObservables);
}
}
我不明白为什么 this.personsObservables 是未定义的,因为如果我调用 getPerson(1) 我正在观察。下一个问题如果有 10/100 或更多项目,如何维护 api 并且我想检测有多少是他们。
有必要:
undefined
错误await
API 调用getPerson
(i)`forkJoin
。所以代码应该是这样的:
const personsObservables = [];
async getPersons(){
for(let i=0;i<10;i++){
this.personsObservables.push(await this.getPerson(i));
}
console.log(this.personsObservables);
return forkJoin(this.personsObservables);
}
让我举个例子:
const request1 = this.http.get('https://restcountries.eu/rest/v1/name/india');
const request2 = this.http.get('https://restcountries.eu/rest/v1/name/us');
const request3 = this.http.get('https://restcountries.eu/rest/v1/name/ame');
const request4 = this.http.get('https://restcountries.eu/rest/v1/name/ja');
const requestArray = [];
requestArray.push(request1);
requestArray.push(request2);
requestArray.push(request3);
requestArray.push(request4);
forkJoin(requestArray).subscribe(results => {
console.log(results);
this.response = results;
});
所有结果都按顺序排列,将项目推送到requestArray.
它可以在stackblitz 示例中看到。
请按以下步骤操作。
export class GetPersonsService {
headers: HttpHeaders = new HttpHeaders().set("Accept", "application/json");
url = "https://swapi.co/api/people/";
personsObservables: Person[] = [];
constructor(private http: HttpClient) {}
getPerson(personIndex: number) {
this.http
.get<Person>(`${this.url}${personIndex}`, { headers: this.headers })
.subscribe(data => {
this.personsObservables.push(data);
});
}
getPersons() {
for (let i = 0; i < 10; i++) {
this.getPerson(i);
}
console.log(this.personsObservables);
}
}
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.