왜 콘솔로그가 두 번 출력되지? 왜 콘솔로그가 두 번 출력되지? : React StrictMode

DANO PARK·2022년 4월 29일
8

무작정 따라하기

목록 보기
4/9
post-thumbnail
post-custom-banner

평화로운 React 공부시간.

React 앱 환경에서 분명 아래와 같이 console.log()를 한 번 작성했는데 개발서버 화면에서는 두 번 출력되고 있었다.

<script>
  console.log('뭐지 콩신의 저주인가?')
  function() {
    return(
      <div>Hello World!<div>
    );
  }
  export default Hello;
</script>

이런 현상은 StrictMode 때문인데, React 환경에서 작성한 코드를 출력하기 위해 만든 index.js 파일에 가면 볼 수 있다.

<script>
  import { StrictMode } from "react";
  import { createRoot } from "react-dom/client";
  import Hello from "./hello";

  const rootElement = document.getElementById("root");
  const root = createRoot(rootElement);

  root.render(
    <StrictMode>
      <Hello />
    </StrictMode>
  );
</script>

StrictMode는 앱에서 잠재적인 문제를 알아내기 위한 도구로, Fragment와 같이 UI를 렌더링하지 않고 자손들에 대한 부가적인 검사와 경고를 활성화한다. StrictMode는 다음과 같은 부분에서 도움을 줄 수 있다.

  • 안전하지 않은 생명주기를 사용하는 컴포넌트 발견
  • 레거시 문자열 ref 사용에 대한 경고
  • 권장되지 않는 findDOMNode 사용에 대한 경고
  • 예상치 못한 부작용 검사
  • 레거시 context API 검사

StrictMode는 개발 모드에서만 활성화되기 때문에, 프로덕션 빌드에는 영향을 끼치지 않는다. 즉 console.log()가 두 번 뜨는 것은 StrictMode로 인한 정상적인 상황으로, 만약 이것이 거슬린다면 index.js에서 출력할 파일을 감싸고 있는 <StrictMode></StrictMode>를 제거하면 된다.

StrictMode 자세히 알아보기

profile
단오해서 단호박!
post-custom-banner

3개의 댓글

comment-user-thumbnail
2022년 5월 2일

오~! 좋은 정보 알아갑니다 감사합니다 :)

답글 달기
comment-user-thumbnail
2022년 5월 4일

ㅋㅋㅋ로그가 너무 웃겨요
잘 보고갑니다

답글 달기
comment-user-thumbnail
2023년 11월 26일

같은 문제로 검색하다 보게 됐는데 유용한 글들이 많네욥ㅎㅎ 재밌게 글 써주셔서 다른 것들도 계속 읽고 있어요 ㅋㅋㅋ 감사합니다!!

답글 달기