useBeforeUnload

这个钩子只是Windows的一个助手。在用户离开页面之前,将重要的应用程序状态保存在页面上(保存到浏览器的本地存储中)可能很有用。这样,如果它们回来,您就可以恢复任何有状态的信息(恢复表单输入值等)

import { useBeforeUnload } from "react-router-dom";

function SomeForm() {
  const [state, setState] = React.useState(null);

  // save it off before users navigate away
  useBeforeUnload(
    React.useCallback(() => {
      localStorage.stuff = state;
    }, [state])
  );

  // read it in when they return
  React.useEffect(() => {
    if (state === null && localStorage.stuff != null) {
      setState(localStorage.stuff);
    }
  }, [state]);

  return <>{/*... */}</>;
}

最后更新于

这有帮助吗?