프레임워크

[Next.js] getServerSideProps Prop이 null로 전달되지 않는 문제

Next.js getServerSideProps prop is null

Next.js 프로젝트에서 getServerSideProps를 사용하여 프리렌더 데이터를 보내는 경우가 있습니다.

export const getServerSideProps = async ({ locale, query }) => {
  return {
    props: {
      preFetchedItem: await axios.get('https://example.com/api/get-examples').then(res => res.data),
    },
  };
};

위에서는 preFetchedItem이라는 prop의 값을 API에서 요청받은 값으로 사용하는 예를 보여줍니다. 이제 preFetchedItem prop을 페이지 컴포넌트의 prop으로 전달받아 사용할 수 있게 됩니다.

const MyPage = ({ preFetchedItem }) => {
  return (
      <div>
        {preFetchedItem}
      </div>
  )
}

하지만 예상과는 달리 값이 undefined 또는 null로 표시되는 경우가 있습니다.

해결 방법

해결 방법은 간단합니다. 이 문제는 Next.js 페이지에서 공통으로 사용하는 _app.js 파일의 레이아웃에서 pageProps라는 이름의 prop을 페이지 컴포넌트에 전달하지 않아서 발생하는 현상입니다.

_app.js 파일을 열고 아래와 같이 pageProps를 전달한 후 다시 시도하면 문제가 해결 될 것입니다.

const RootApp = ({
  Component,
  pageProps,
  ...other
}) => (
  <Component {...other} {...pageProps} />
);

export default RootApp;

JooTC

안녕하세요. 테크놀로지에 관심이 많은 블로거입니다.

Recent Posts

Zalgo 텍스트와 이를 방지하는 방법

인터넷 커뮤니티 사이트에서 게시글이나 댓글에 간혹 장난을 목적으로 작성된 특이한 글자를 볼 수 있습니다. 위…

4주 ago

리눅스 kill, killall 명령어 – 특정 프로세스 종료하기

리눅스 명령어 - kill, killall 리눅스 kill 명령어는 특정 프로세스를 종료해주는 명령어입니다. 백그라운드에서 실행되고 있는…

4주 ago

JavaScript typeof null이 ‘object’인 이유

JavaScript는 역사가 긴 스크립트 프로그래밍 언어입니다. 세월이 흐르면서 많은 자바스크립트 표준이 만들어졌고, 현재는 많은 문법적…

4주 ago

Mocha Error: Resolution method is overspecified. 해결 방법

NodeJS 테스트 프레임워크인 Mocha는 비동기 테스트를 지원합니다. 간혹 특정 테스트 스크립트를 작성하고 실행하면 아래와 같이…

4주 ago

윈도우 11 설치 시 Microsoft 계정 로그인 없이 로컬 계정 만들기

언제부턴가 윈도우 11을 처음 설치할 때 마이크로소프트(Microsoft) 계정 로그인을 강제로 요구하게 되었습니다. 물론 마이크로소프트 계정이…

6개월 ago

에어팟 프로 2 케이스 스피커 소리를 완전히 끄는 방법

애플 에어팟 프로 2 (AirPods Pro 2) 케이스에는 스피커가 내장되어 있습니다. 그런데 간혹 아무 것도…

9개월 ago