繁体   English   中英

从Angular 5中的http.get返回单个项目的Observable

[英]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.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM