Я не получаю rxjs 6 с угловым 6 с интервалом, switchMap и map - PullRequest
0 голосов
/ 06 мая 2018

Я хочу обновить свой код rxjs до 6, я не получаю его.

До того, как я проводил опрос о новых данных каждые 5 секунд:

import { Observable, interval } from 'rxjs';
import { switchMap, map } from 'rxjs/operators';

var result = interval(5000).switchMap(() => this._authHttp.get(url)).map(res => res.json().results);

Теперь ... конечно, он сломан и документация не оставляет меня.

Как мне написать выше, чтобы соответствовать rxjs 6?

Спасибо

Ответы [ 2 ]

0 голосов
/ 24 августа 2018

После большого количества исследований я мог придумать следующий обновленный подход из RxJs '6 с Angular 6 .

API поиска вызывается после каждого интервала в 5 секунд и отписывается после счета> 5:

let inter=interval(5000)

let model : ModelComponent;
model=new ModelComponent();
model.emailAddress="mdshahabaz.khan@gmail.com";


let count=1;
this.subscriber=inter.pipe(
          startWith(0),
          switchMap(()=>this.asyncService.makeRequest('search',model))
        ).subscribe(response => {
          console.log("polling")
          console.log(response.list)
          count+=1;
          if(count > 5){
            this.subscriber.unsubscribe();
          }
        });

Запрос API:

   makeRequest(method, body) : Observable<any> {
    const url = this.baseurl + "/" + method;

    const headers = new Headers();
    this.token="Bearer"+" "+localStorage.getItem('token'); 
    headers.append('Authorization', this.token);
    headers.append('Content-Type','application/json');

    const options = new RequestOptions({headers: headers});
    return this.http.post(url, body, options).pipe(
        map((response : Response) => {
            var json = response.json();                

           return json; 
        })
    );
}

Не забудьте отписаться, чтобы избежать утечки памяти.

ngOnDestroy(): void {
if(this.subscriber){
  this.subscriber.unsubscribe();
}

}

0 голосов
/ 06 мая 2018

Код должен быть примерно таким: Вам нужно использовать оператор pipe.

import { interval } from 'rxjs';
import { switchMap, map } from 'rxjs/operators';

const result = interval(5000).pipe(
switchMap(() => this._authHttp.get(url)),    
map(res => res.results)
)
...