[英]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.