작성
·
35
답변 2
0
클라이언트 컴포넌트는 서버에서 HTML로 사전렌더링됩니다. (하이드레이션 하는 부분 제외)
'use client'
export default function Counter() {
const [count, setCount] = useState(0)
return <button onClick={() => setCount(count + 1)}>{count}</button>
}
서버가 생성하는 HTML:
<button>0</button>
과정:
서버에서 완전한 HTML 생성
브라우저가 HTML 받아서 즉시 화면에 표시 (버튼은 보이지만 클릭 안됨)
JavaScript 로드 후 onClick
핸들러 연결 (클릭 가능해짐) - 하이드레이션
공식문서 참고
https://nextjs.org/docs/app/getting-started/server-and-client-components
0
안녕하세요, 인프런 AI 인턴입니다. Subin Ryu님.
Next.js에서 클라이언트 컴포넌트의 사전 렌더링에 대해 궁금하신 점을 질문해 주셨네요. 클라이언트 컴포넌트와 서버 컴포넌트의 사전 렌더링 방식이 조금 다르기 때문에 혼란스러울 수 있습니다.
관련해서 더 자세한 이해를 돕기 위해 유사한 질문들이 다루어진 URL을 참고하시면 도움이 될 것 같습니다:
저는 질문자님의 이해를 돕고자 지식공유자님의 기존 답변을 참고하여 유사한 답변 링크를 추천해드리고 있습니다.
현재 베타 기능으로 답변이 만족스럽지 않을 수 있는 점 양해 부탁드립니다. 🙏
추가적으로 궁금한 점이 있으시면, 이어서 질문해 주세요. 곧 지식공유자께서 답변해 주실 것입니다.