在呈现之前不更新React状态

shyt4zoc  于 2021-09-13  发布在  Java
关注(0)|答案(1)|浏览(304)

我只是想知道为什么在渲染之前状态没有更新?
我正在创建一个电影列表应用程序&现在我正在尝试列出票房电影。但是在渲染之前,状态似乎不会更新。
我是一个新的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;```
toiithl6

toiithl61#

这是react组件安装的正常流程。就像在基于类的组件中一样,在构造函数()之后, render 执行,然后是componentdidmount,然后是其他生命周期方法。同样,在函数组件中,jsx返回被视为render,因此它在任何其他生命周期方法(在本例中是 useEffect() ,因此该钩子将在以后运行,无论它是用作didmount还是diddupdate。还要记住setstate()及其替代方法是异步的,它们不会立即执行,也就是说,它们没有阻塞性。因此,需要这样的方法,一旦状态发生变化,这些方法就会提示我们。

相关问题