如何在Angular2中使用带有Observable的id查找数组的元素

Gab*_*orH 13 observable rxjs typescript angular

我决定使用Observable而不是Http承诺.

这就是我的Promise服务的样子:

export class MovieService {

    movies: Movie[]
    movie: Movie;
    constructor(private http:Http) { }

   getMovies(): Promise<Movie[]>{

        return this.http.get('http://api.request.com')
            .toPromise()
            .then((res:Response) => res.json()['results'])

    }
    getMovie(id: number): Promise<Movie> {
        return this.getMovies()
            .then(movies => movies.find(movie => movie.id == id));

    }

}
Run Code Online (Sandbox Code Playgroud)

首先我获取一组电影,而不是通过id找到某个数组的电影.但是,当我尝试对Observable执行相同操作时,我收到有关find的错误通知:属性'find'在类型'Movie []'上不存在.

以下是我尝试使用Observable服务的内容:

export class MovieService {

    movies: Movie[];
    movie: Movie;

    constructor(private http: Http) {
    }

    getMovies(): Observable<Movie[]> {

        return this.http.get('http://api.request.com)
            .map((res: Response) => res.json()['results']);
    }

    getMovie(id: number): Observable<Movie> {
        return this.getMovies()
            .subscribe(movies => movies.find(movie => movie.id == id));
    }
}
Run Code Online (Sandbox Code Playgroud)

如何在我的Observable服务中实现相同的功能,就像在我的Promise服务中一样?

yur*_*zui 18

我想你应该使用map方法而不是subscribe返回Subscription对象

export class MovieService {
  movies: Movie[];
  movie: Movie;

  constructor(private http: Http) {}

  getMovies(): Observable<Movie[]> {
    return this.http.get('http://api.request.com')
      .map((res: Response) => res.json()['results']);
  }

  getMovie(id: number): Observable<Movie> {
    return this.getMovies()
      .map(movies => movies.find(movie => movie.id == id));
  }
}
Run Code Online (Sandbox Code Playgroud)

Plunker示例

  • @Siri0S 没有堆栈跟踪,我只是无法在电影上调用 find 方法。当我将鼠标悬停在查找上时,它说:“电影[]”类型上不存在属性“查找”。 (2认同)