![](/img/trans.png)
[英]Angular 2 : Get 404 error in http.get call with Observable return
[英]Return Observable of single item from http.get in Angular 5
我有一项将请求发送到内存Web API的服务。 该服务包括一个我想查询(通过查询字符串)单个项目的API的方法。
无论在通用的http.get方法中指定单个项目,我都会返回一个数组。
这与我仅返回单个项目时使用ID而不是查询使用单个项目的API调用API的情况不同。
this.http.get<ITrack>(`api/tracks/1`)
.subscribe(track => console.log(JSON.stringify(track)));
退货
{"id":1,"artist":"Radiohead","name":"OK Computer","durationSeconds":61,"nominator":null,"playlistPosition":1}
在哪里
this.http.get<ITrack>(`api/tracks/?playlistPosition=1`)
.subscribe(track => console.log(JSON.stringify(track)));
退货
[{"id":1,"artist":"Radiohead","name":"OK Computer","durationSeconds":61,"nominator":null,"playlistPosition":1}]
我可以接到第二个电话,只返回以下内容:
this.http.get<ITrack>(`api/tracks/?playlistPosition=1`)
.pipe(
map(t => t[0])
)
.subscribe(track => console.log(JSON.stringify(track)));
但是,我不能使用诸如single或first之类的方法,因为编译器希望返回的是ITrack类型。
在这里退货的正确方法是什么?
因此,如果端点始终返回列表,请调用以ITrack
键入的get
方法。
只需将.get<ITrack>(...)
替换为.get<ITrack[]>(...)
。
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.