React useHash 훅

Beginner

This tutorial is from open-source community. Access the source code

소개

이 랩에서는 React 에서 브라우저의 위치 해시 값을 추적하고 업데이트하기 위해 useHash 훅을 사용하는 방법을 배웁니다. 이 훅은 해시 값에 따라 페이지의 다른 컴포넌트 또는 섹션을 표시하는 싱글 페이지 애플리케이션 (Single-Page Application, SPA) 을 만들 때 유용합니다. 이 랩을 마치면 React 프로젝트에서 useHash 훅을 구현하고 웹 애플리케이션의 사용자 경험을 향상시킬 수 있습니다.

React useHash 훅

index.htmlscript.js는 이미 VM 에 제공되었습니다. 일반적으로 script.jsstyle.css에만 코드를 추가하면 됩니다.

이 코드는 브라우저의 위치 해시 값을 추적하고 업데이트합니다. 사용하려면 다음 단계를 따르세요.

  1. useState() 훅을 사용하여 Location 객체의 hash 속성을 지연 로딩 (lazily) 으로 가져옵니다.
  2. useCallback() 훅을 사용하여 'hashchange' 이벤트가 발생할 때 hash 상태를 업데이트하는 핸들러를 생성합니다.
  3. useEffect() 훅을 사용하여 마운트 시 'hashchange' 이벤트에 대한 리스너를 추가하고 언마운트 시 정리합니다.
  4. useCallback() 훅을 사용하여 주어진 값으로 Location 객체의 hash 속성을 업데이트하는 함수를 생성합니다.
  5. 컴포넌트에서 useHash()를 호출하여 현재 hash 값과 이를 변경하는 updateHash() 함수를 가져옵니다.
  6. updateHash() 함수를 사용하여 hash 값을 변경합니다.
  7. 컴포넌트에서 현재 hash 값을 렌더링합니다.
  8. 사용자가 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>Current hash value: {hash}</p>
      <p>Edit hash: </p>
      <input value={hash} onChange={(e) => setHash(e.target.value)} />
    </>
  );
};

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

오른쪽 하단의 'Go Live'를 클릭하여 포트 8080 에서 웹 서비스를 실행하십시오. 그런 다음 Web 8080 탭을 새로 고쳐 웹 페이지를 미리 볼 수 있습니다.

요약

축하합니다! React useHash 훅 랩을 완료했습니다. LabEx 에서 더 많은 랩을 연습하여 기술을 향상시킬 수 있습니다.