简体   繁体   English

用 Axios 请求填充 React state

[英]Fill React state with Axios request

The first request give me IDs from my database, and put results in state. I use it to make a request to the API The movie database for each ID.第一个请求从我的数据库中给我 ID,并将结果放入 state。我用它向 API 请求每个 ID 的电影数据库。

I need to put data from the API in the second state.我需要将 API 中的数据放入第二个 state 中。

The problem is that only one film data remains at the end.问题是最后只剩下一个电影数据。

After that, I would like to use the map function on the state, but I don't know if it's possible.之后想在state上使用map function,不知道可不可以。

function App() {
  const [movieid, setMovieid] = useState([]);
  const [movieinfos, setMovieinfos] = useState([]);

  useEffect(() => {
    axios
      .get("http://localhost:5000")
      .then(function (response) {
        // handle success
        console.log(response.data.movies);

        setMovieid(response.data.movies);
      })

      .catch(function (error) {
        // handle error
        console.log(error);
      });
  }, []);

  console.log(movieid);

  useEffect(() => {
    for (const movie of movieid) {
      console.log(movie.movieid);
      axios
        .get(`${BASE_URL}${movie.movieid}?api_key=${API_KEY}&language=fr`)

        .then(function (response) {
          // handle success
          console.log(response);
          setMovieinfos(...movieinfos, response.data);
        })
        .catch(function (error) {
          // handle error
          console.log(error);
        });
    }
  }, [movieid]);

  useEffect(() => {
    console.log(movieinfos);
  }, [movieinfos]);
  return (
    <div className="App">
      <div className="Header">
        <Logo />
      </div>
      <div className="Menu">
        <Search />
        <Add_movie_button />
        <Delete_movie_button />
        <Random_movie_button />
      </div>
      <div className="Movies">
        {movieid.map((movie) => (
          <Movie_card />
        ))}
      </div>
    </div>
  );
}

export default App;

Problem solvedby putting an array (i had misplaced it when I tried first)通过放置数组解决了问题(我第一次尝试时放错了位置)

function App() {

  const [movieid, setMovieid] = useState([]);
  const [movieinfos, setMovieinfos] = useState([]);
  let moviesData = [] 
  
useEffect(() => {
  axios.get('http://localhost:5000')
  .then(function (response) {
    // handle success
    console.log(response.data.movies)
    
    
      setMovieid(response.data.movies)
    
    
  })

  .catch(function (error) {
    // handle error
    console.log(error);
  })
     
  
}, []);

console.log(movieid)

useEffect(() => {
for (const movie of movieid) {
console.log(movie.movieid)
 axios.get(`${BASE_URL}${movie.movieid}?api_key=${API_KEY}&language=fr`) 

  .then(function (response) {
    // handle success
    console.log(response)
    
    moviesData.push(response.data)
    setMovieinfos(
      moviesData
      );
      
  })
  .catch(function (error) {
    // handle error
    console.log(error);
  })

  }

}, [movieid]);

useEffect(() => {
console.log(movieinfos)
}, [movieinfos]);
  return (
    <div className="App">
      <div className="Header">
        <Logo />
      </div>
      <div className="Menu">
        <Search />
        <Add_movie_button />
        <Delete_movie_button />
        <Random_movie_button />
      </div>
      <div className="Movies">
        
        {movieid.map(movie => <Movie_card />)}
         

      </div>
      
    </div>
  );
}

export default App;

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

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