React useHash钩子

跟踪浏览器的位置哈希值,并允许更改它。

  • 使用useState()钩子来惰性获取Location对象的hash属性。
  • 使用useCallback()钩子创建一个更新状态的处理程序。
  • 使用useEffect()钩子在挂载时添加一个监听器来监听'hashchange'事件,并在卸载时清理它。
  • 使用useCallback()钩子创建一个函数,用给定的值更新Location对象的hash属性。
const useHash = () => {
  const [hash, setHash] = React.useState(() => window.location.hash);

  const hashChangeHandler = React.useCallback(() => {
    setHash(window.location.hash);
  }, []);

  React.useEffect(() => {
    window.addEventListener('hashchange', hashChangeHandler);
    return () => {
      window.removeEventListener('hashchange', hashChangeHandler);
    };
  }, []);

  const updateHash = React.useCallback(
    newHash => {
      if (newHash !== hash) window.location.hash = newHash;
    },
    [hash]
  );

  return [hash, updateHash];
};

const MyApp = () => {
  const [hash, setHash] = useHash();

  React.useEffect(() => {
    setHash('#list');
  }, []);
  return (
    <>
      <p>window.location.href: {window.location.href}</p>
      <p>编辑哈希值: </p>
      <input value={hash} onChange={e => setHash(e.target.value)} />
    </>
  );
};

ReactDOM.createRoot(document.getElementById('root')).render(
  <MyApp />
);