3️서버 컴포넌트
Next.js 13을 알차게 활용하려면 React 18을 어느정도 이해해야 합니다. 그 중에서도 React Server Component(이하 RSC)가 중요하죠. 본격적인 Next.js 학습 전에 RSC에 대해 간단히 살펴보고 넘어가겠습니다.
서버 컴포넌트가 필요한 이유
React는 서버에서 렌더링 할 수 있는 컴포넌트인 RSC를 제공함으로써 개발자가 원하는 곳에서 컴포넌트를 렌더링 할 수 있는 선택지를 제공한다고 설명합니다.
기존의 Server Side Rendering(SSR)과 다른 점을 간단하게 정리하자면 SSR은 서버에서 페이지 단위로 정적인 리소스를 생성하지만 RSC는 컴포넌트 단위로 정적인 리소스를 생성할 수 있다는 점입니다.
여기서 RSC의 가장 큰 장점이 나옵니다. 클라이언트로 내려보내는 JavaScript 번들 크기를 줄일 수 있게 되는 것이죠. 뿐만아니라 데이터베이스와 보다 가까운 곳에서 데이터를 조회하기 때문에 속도도 더 빨라질 수 있습니다. 이는 PHP, Ruby on Rails와 유사하지만 우리에게 익숙한 React라는 라이브러리를 활용할 수 있다는 점에서 매력적이죠.
이러한 장점 덕분에 Next.js에서는 RSC를 기본 컴포넌트 렌더링 방식으로 채택하고 있습니다. 하지만 모든 컴포넌트를 RSC로 만들 순 없습니다.
서버 컴포넌트 혹은 클라이언트 컴포넌트
브라우저 API를 사용하거나 useState
, useEffect
등의 훅을 이용해야하는 경우에는 여전히 클라이언트 컴포넌트를 사용해야하죠. 이럴 땐 파일 가장 첫 줄에 'use client'
라고 명시해야 합니다.
아래의 표는 서버 컴포넌트와 클라이언트 컴포넌트를 사용해야 하는 경우를 구분 지어뒀습니다. (출처)
원하는 것 | 서버 컴포넌트 | 클라이언트 컴포넌트 |
---|---|---|
데이터 가져오기 | ✅ | ✘ |
백엔드 리소스에 직접 접근하기 | ✅ | ✘ |
민감한 정보를 서버에 보관할 때(액세스 토큰, API 키 등) | ✅ | ✘ |
JavaScript 리소스 줄이기 | ✅ | ✘ |
상호작용 및 이벤트 리스너( | ✘ | ✅ |
상태 및 생애 주기 관리( | ✘ | ✅ |
브라우저 API 사용하기 | ✘ | ✅ |
React 클래스 컴포넌트 사용하기 | ✘ | ✅ |
서버 컴포넌트 활용 패턴
"아니, 뭐야 useState
, useEffect
같은 훅을 사용하지 못하고 이벤트 리스너도 사용하지 못하면 자주 쓸 일이 있긴 한거야?" 하는 생각이 드실겁니다. 그래서 Next.js에선 클라이언트 컴포넌트를 최대한 말단(Leaves)으로 내려보내길 권합니다.
클라이언트 컴포넌트를 최대한 말단으로 내려보내라는 건 서버 컴포넌트에서 클라이언트 컴포넌트를 불러오는 동작은 문제가 없다는 것을 의미합니다. 반면, 클라이언트 컴포넌트에서 서버 컴포넌트를 불러오는 패턴은 지원되지 않습니다. 아래의 코드는 동작하지 않는 예시입니다. (출처)
직접 불러올 순 없지만 자식 요소로 전달할 순 있습니다.
이 같은 RSC의 특징을 이해하고 나면 Next.js를 알차게 쓸 수 있습니다.
참고 자료
Last updated