Mar*_*ine 2 rxjs angular angular9
我正在尝试创建一个动态组件,它将采用 api url 和 IntervalPeriod 表示“x”分钟作为输入,并每隔 x 分钟获取作为输入传递的数据。
这是我尝试遵循所有 stackoverflow 答案的 stackblitz。
我需要在 0 秒时第一次显示数据,之后必须每隔 x 秒或每分钟获取数据。这看起来正确还是我在这里缺少什么?
https://stackblitz.com/edit/angular-wzvwmy?file=src%2Fapp%2Fdata-emitter%2Fdata-emitter.component.ts
import { Component, Input, OnInit, Output } from "@angular/core";
import { interval } from "rxjs";
import { flatMap, map } from "rxjs/operators";
import { Http } from "@angular/http";
@Component({
selector: "app-data-emitter",
templateUrl: "./data-emitter.component.html",
styleUrls: ["./data-emitter.component.css"]
})
export class DataEmitterComponent implements OnInit {
@Output() data: any;
@Input() apiUrl: any;
@Input() intervalPeriod: number;
minutes: number;
constructor(private http: Http) {}
ngOnInit() {
this.minutes = this.intervalPeriod * 60 * 1000;
}
subscribes$ = interval(this.minutes)
.pipe(flatMap(() => this.getData()))
//this.getData()
.subscribe(data => {
this.data = data;
console.log(this.data);
});
getData() {
return this.http
.get(this.apiUrl)
.pipe(map((response: any) => response.json()));
}
}
Run Code Online (Sandbox Code Playgroud)
Yan*_*p-H 10
有几件事我会改变:
import { Component, Input, OnDestroy, OnInit, Output } from "@angular/core";
import { HttpClient } from '@angular/common/http';
import { of, Subscription, timer } from "rxjs";
import { catchError, filter, switchMap } from "rxjs/operators";
@Component({
selector: "app-data-emitter",
templateUrl: "./data-emitter.component.html",
styleUrls: ["./data-emitter.component.css"]
})
export class DataEmitterComponent implements OnInit, OnDestroy {
@Output() data: any;
@Input() apiUrl: any;
@Input() intervalPeriod: number;
minutes: number;
subscription: Subscription;
constructor(private http: HttpClient) {}
ngOnInit() {
this.minutes = this.intervalPeriod * 60 * 1000;
this.subscription = timer(0, this.minutes)
.pipe(
switchMap(() => {
return this.getData()
.pipe(catchError(err => {
// Handle errors
console.error(err);
return of(undefined);
}));
}),
filter(data => data !== undefined)
)
.subscribe(data => {
this.data = data;
console.log(this.data);
});
}
ngOnDestroy() {
this.subscription.unsubscribe();
}
getData() {
return this.http
.get(this.apiUrl);
}
}
Run Code Online (Sandbox Code Playgroud)
| 归档时间: |
|
| 查看次数: |
6583 次 |
| 最近记录: |