我只是想知道为什么在渲染之前状态没有更新?
我正在创建一个电影列表应用程序&现在我正在尝试列出票房电影。但是在渲染之前,状态似乎不会更新。
我是一个新的React,我真的很感谢一些帮助和解释为什么会发生这种情况
const BoxOffice = () => {
const [data, setData] = useState([]);
const getBoxOffices = async () => {
var options = {
method: "GET",
url: "https://movies-tvshows-data-imdb.p.rapidapi.com/",
params: { type: "get-boxoffice-movies", page: "1" },
headers: {
"x-rapidapi-key": "4ccc11616emsha0ff93487313f1ep1528a9jsnf24cc1750061",
"x-rapidapi-host": "movies-tvshows-data-imdb.p.rapidapi.com",
},
};
axios
.request(options)
.then((response) => {
console.log(response.data.movie_results);
const boxOfficeMovies = response.data.movie_results;
setData(boxOfficeMovies);
})
.catch((error) => {
console.error(error);
});
};
const getfullData = async () => {
getBoxOffices();
console.log("data", data);
};
useEffect(() => {
getfullData();
}, []);
return (
<div>
<div className="min-h-screen w-screen bg-gray-300 pt-12">
<div className="min-w-auto grid grid-flow-row grid-cols-5 gap-4 items-center justify-center mt-5">
<div className="w-screen bg-red-50">
{data && <Card data={data} />}
</div>
</div>
</div>
</div>
);
};
export default BoxOffice;```
1条答案
按热度按时间toiithl61#
这是react组件安装的正常流程。就像在基于类的组件中一样,在构造函数()之后,
render
执行,然后是componentdidmount,然后是其他生命周期方法。同样,在函数组件中,jsx返回被视为render,因此它在任何其他生命周期方法(在本例中是useEffect()
,因此该钩子将在以后运行,无论它是用作didmount还是diddupdate。还要记住setstate()及其替代方法是异步的,它们不会立即执行,也就是说,它们没有阻塞性。因此,需要这样的方法,一旦状态发生变化,这些方法就会提示我们。