2

我有一个附加到按钮的方法。用户在输入中输入他们的姓名,当单击按钮时,将显示来自该用户的信息。我打算如何做到这一点在下面解释..

我正在尝试将一个 Observable 中的值传递给另一个 Observable。我试图从第一个 Observable 获得的值是一个 ID,然后在第二个 Observable 中使用。

我目前这样做的方法是使用 switchMap 运算符。但是,当将 ID 从第一个 Observable 传递到第二个时,我在控制台中看到“未定义”..

我在想,要么我在调用第一个 Observable 时没有正确访问 ID。要么我不应该使用 switchMap ?

这也很奇怪,我认为我很接近,因为使用 Object.keys(player)['0'] 我可以获得第一个对象键(数据)。但是使用 Object.keys(player)['0'].id; 未定义:/

这是我试图从中获取 ID 的响应对象:

伊姆古尔

我的组件中的单击功能:

click() {
  this.playerService.getPlayer(this.searchString).pipe(
      switchMap(player => {
        let ID = Object.keys(player)['0'];
        let anotherID = ID['0'].id;

        return this.playerService.getSeasonStats(anotherID);
      }))
    .subscribe(id => this.player = id)
}

使用 getPlayer 方法和 getSeasonStats 方法的服务:

getPlayer(query: string):Observable<Player> {
  let getHeaders = new HttpHeaders({'Authorization':'Bearer API_Key', 'Accept': 'application/vnd.api+json'}); 
  return this.http.get<Player>(`https://api.com/shards/steam/players?filter[playerNames]=${query}`, {
    observe:'body',
    responseType: 'json',
    headers: getHeaders
  });
}


getSeasonStats(id: string):Observable<SeasonStats[]> {
  let getHeaders = new HttpHeaders({'Authorization':'Bearer API_Key', 'Accept': 'application/vnd.api+json'}); 
  return this.http.get<SeasonStats[]>(`https://api.com/shards/steam/players/${id}/seasons/division.bro.official.pc-2018-04`,  {
    observe:'body',
    responseType: 'json',
    headers: getHeaders
  });
}
4

1 回答 1

2

你的问题是:

let ID = Object.keys(player)['0'];
let anotherID = ID['0'].id;

该行将Object.keys(player)['0']"data"作为字符串返回,现在['0']您得到“d”...所以您的结果是"d".id => undefined

也许您需要执行以下操作:

let playerData = player["data"][0];
let anotherID = playerData.id;
于 2019-10-16T18:45:35.097 回答