这 2 个 HTTP Get 语句是否相等?这张地图有什么作用?
Are those 2 HTTP Get Statements equal? What does this map do?
我关注了一个文档,他们在其中使用了:
findLessons(): Observable<Lesson[]> {
return this.http.get('http://localhost:3000/api/lessons').pipe(
map(res => res["payload"])
);
}
但是这没有用,我得到了一个未定义的。
我想到了这个解决方案,效果很好:
findLessons(): Observable<Lesson[]> {
return this.http.get<Lesson[]>('http://localhost:3000/api/lessons');
}
那么为什么 1 不起作用?解决方案是一样的吗?首选哪种解决方案?
在第一个示例中,您收到 API 响应,但您只对 return 发送 payload
属性 感兴趣。您未定义,这意味着 API 响应不包含 payload
属性.
在第二个示例中,您收到了一个 API 响应,您希望它反序列化为 Lesson[]
并且您将要 return 它。
这不是首选解决方案的问题,您正在做不同的事情,显然第一个不符合您的 API 回复。
谈到“首选”事物,表示法 res.payload
优于 res["payload"]
。
我关注了一个文档,他们在其中使用了:
findLessons(): Observable<Lesson[]> {
return this.http.get('http://localhost:3000/api/lessons').pipe(
map(res => res["payload"])
);
}
但是这没有用,我得到了一个未定义的。
我想到了这个解决方案,效果很好:
findLessons(): Observable<Lesson[]> {
return this.http.get<Lesson[]>('http://localhost:3000/api/lessons');
}
那么为什么 1 不起作用?解决方案是一样的吗?首选哪种解决方案?
在第一个示例中,您收到 API 响应,但您只对 return 发送 payload
属性 感兴趣。您未定义,这意味着 API 响应不包含 payload
属性.
在第二个示例中,您收到了一个 API 响应,您希望它反序列化为 Lesson[]
并且您将要 return 它。
这不是首选解决方案的问题,您正在做不同的事情,显然第一个不符合您的 API 回复。
谈到“首选”事物,表示法 res.payload
优于 res["payload"]
。