해결된 질문
작성
·
28
0
안녕하세요, 우선 강의 너무 잘 들었습니다.
사전 렌더링에 대한 부분에서 궁금중이 있어 문의를 남깁니다.
클라이언트 컴포넌트 또한 서버에서 JS 실행을 통해 서버 측에서 사전 렌더링이 된다는 것을 알고 있습니다.
다만, 서버에서 실행되는 사전 사이드 렌더링의 경우 useEffect, useState 등과 같은 훅은 어떤 식으로 실행이 되는지 궁금합니다.
왜냐하면 서버 클라이언트에서는 훅 사용이 불가능한 것으로 알고 있는데, 이는 곧 서버에서 훅을 사용하지 못한다는 뜻으로 이해하고 있어서요.
만약 해당 훅 들이 서버에서 실행되지 않고, 컴포넌트에 마운트 된 이후에 실행 되는 것이라면, 컴포넌트 return 문 안에 있는 State나 로직들은 undefined 인 상태에서 렌더링 되어 Client에 HTML 형태로 전달 되는 것일까요?
또한 비슷한 질문인데, 사전 렌더링에서 local storage, DOM 조작 등과 같이 Client에서만 접근 가능한 API에서는 어떤 식으로 사전 렌더링이 진행되는지, 그리고 초기 HTML을 그릴 때는 해당 값들을 어떻게 처리하는 지 궁금합니다.
좋은 강의 감사합니다!
답변 2
1
안녕하세요 이정환입니다.
결론부터 말씀드리자면, 사전 렌더링 과정 중 클라이언트 컴포넌트는 초기 UI를 렌더링 하는 방향으로만 동작해요 useState를 통해 만든 State는 초기값으로 사용되고, useEffect 등은 마운트 이후에만 동작하니 아예 동작하지 않게 됩니다.
로컬 스토리지나 DOM 조작 등의 브라우저 API를 이용하는 경우에는 오류가 발생해요! 이런 코드는 서버 측에서는 접근 자체가 불가능 하기 때문에 조건문 등을 통해 브라우저 환경에서만 실행되도록 막아두셔야 합니다.
0
안녕하세요, 인프런 AI 인턴입니다.
itjustbong님의 클라이언트 컴포넌트의 사전 렌더링 과정에 대한 질문에 대해 답변을 드리겠습니다. Next.js나 React의 서버 측 렌더링에서 사용되는 훅(useEffect
, useState
등)의 동작 원리에 대한 궁금증은 많은 개발자들이 접하는 주제입니다.
훅이 서버에서 어떻게 동작하는가?
서버에서 클라이언트 컴포넌트가 사전 렌더링될 때, React 훅인 useEffect
는 서버 쪽에서 실행되지 않습니다. 이는 useEffect
가 주로 브라우저 환경에서 실행되어야 하는 로직(부수 효과)들을 처리하기 때문입니다. 대신, useState
의 경우 초기값에 기반하여 서버에서도 초기 상태를 적용할 수 있으며, 이 상태는 사전 렌더링된 HTML의 일부로 포함됩니다. 하지만 초기 상태 이후의 상태 변화는 클라이언트 측에서 초기화됩니다.
useEffect
와 같은 훅 사용 시 서버에서의 불가능성:
사전 렌더링할 때 useEffect
와 같은 훅은 서버 환경에서는 처리되지 않습니다. 서버 렌더링은 주로 ‘첫 번째 페인트’에 필요한 최소한의 HTML을 제공하기 때문에, 이후의 클라이언트 상호작용(상태 변경 등)은 클라이언트의 역할로 남겨둡니다.
사전 렌더링과 클라이언트 전용 API(Local Storage, DOM 조작 등):
서버에서만 실행되는 사전 렌더링에서는 클라이언트 전용 API(Local Storage, DOM 조작 등)에 접근할 수 없습니다. 이러한 경우, 코드가 클라이언트에서만 실행되도록 조건문(예: typeof window !== "undefined"
)을 사용하여 브라우저에서만 해당 로직을 실행하도록 분리해야 합니다.
이와 관련된 추가 질문이 있을 경우 “Next.js 사전 렌더링에 대해서 더 궁금한 부분이 있습니다.”를 참고하시면 도움이 될 수 있습니다. 이 질문에서는 사전 렌더링과 Hydration 과정 및 초기 HTML 제공 방식에 대해 더 깊이 있는 설명을 제공합니다.
저는 질문자님의 이해를 돕고자 지식공유자님의 기존 답변을 참고하여 유사한 답변 링크를 추천해드리고 있습니다.
현재 베타 기능으로 답변이 만족스럽지 않을 수 있는 점 양해 부탁드립니다. 🙏
추가적으로 궁금한 점이 있으시면, 이어서 질문해 주세요. 곧 지식공유자께서 답변해 주실 것입니다.