2

在这个 React 组件中,我试图从 GIPHY API 获取数据并将其呈现在另一个组件中。提取工作正常,但this.state.gifs.map返回错误,因为它在提取完成和状态设置之前运行。我曾尝试将 Hooks 与 async/await 一起使用,但这似乎也不起作用。在设置状态后如何创建我gifArray的,这样我就不会尝试.map在空数组上运行。

import React, {Component} from 'react'
import GifCard from './gifCard.js'
import './App.css'

export default class GifContainer extends Component{

  state = {
    gifs: []
  }

  componentDidMount(){
    fetch('http://api.giphy.com/v1/gifs/search?q=ryan+gosling&api_key=KnzVMdxReB873Hngy23QGKAJh6WtUnmz&limit=5')
    .then(res => res.json())
    .then(gifs => {
      this.setState({gifs})
    })
  }


  render(){
    const gifArray = this.state.gifs.map((gif) => {
      return <GifCard key={gif.name} gif={gif}/>
    })
    return(
      <div>
        <h1 id="heading">Gif Search</h1>
        <div id='gifContainer'>
          {gifArray}
        </div>
      </div>

    )}

}
4

2 回答 2

3

您的加载和状态管理实际上很好 - 在空数组上运行 map 不会导致错误。

您的问题实际上与您要返回的数据有关。我检查了您正在使用的 URL 的响应,它返回一个包含数据和分页详细信息的对象,如下所示:

{
  data: [
    // The gif array
  ],
  pagination: {...},
  meta: {...}
}

在这个对象上使用map会给你一个错误。gif 数组位于data您应该使用的属性中 - 例如,而不是:

this.setState({gifs})

您可以使用:

this.setState({gifs: gifs.data})
于 2020-03-05T05:27:02.420 回答
3

您必须首先检查 gifs 数组是否为空。当 setState 完成后,render 会再次触发,这次会有 gif 来映射。

    let gifArray = '';

    if (this.state.gifs.length > 0) {
        gifArray = this.state.gifs.map((gif) => {
          return <GifCard key={gif.name} gif={gif}/>
        })
    }
于 2020-03-05T05:02:20.617 回答