gpt4 book ai didi

angular - 如何在 Angular2 中使用 Observable 通过 id 查找数组元素

转载 作者:太空狗 更新时间:2023-10-29 17:04:46 27 4
gpt4 key购买 nike

我决定使用 Observable 而不是 Http promises。

这就是我的 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));

}

}

首先我获取了一个电影数组,然后我通过 id 找到了数组中的某部电影。但是,当我尝试对 Observable 执行相同操作时,我在查找时收到错误通知:属性“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));
}
}

如何在我的 Observable 服务中实现与在我的 Promise 服务中相同的功能?

最佳答案

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

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));
}
}

Plunker Example

关于angular - 如何在 Angular2 中使用 Observable 通过 id 查找数组元素,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/40495483/

27 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com