这 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"]