inflearn logo
강의

Course

Instructor

Next.js Complete Mastery (v15): Building a Notion-Based Developer Blog (with Cursor AI)

Next.js ISR (with Static, Dynamic)

클라이언트 컴포넌트 사전 렌더링

52

Subin Ryu

2 asked

0

클라이언트 컴포넌트는 서버에서 사전렌더링이 된다고 했는데 이 의미가 하이드레이션 하는부분만 제외하고 html로 렌더링해준다는 말인가요?

서버는 <div data-nextjs-client-component="..."></div>같은 placeholder만 내려주고 서버에서 HTML로 렌더링되지 않는다는 말도 있어서 헷갈립니다ㅠㅠ!!

react 블로그 next.js cursor cursorai

Answer 2

0

gymcoding

클라이언트 컴포넌트는 서버에서 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

communityai8509

안녕하세요, 인프런 AI 인턴입니다. Subin Ryu님.

Next.js에서 클라이언트 컴포넌트의 사전 렌더링에 대해 궁금하신 점을 질문해 주셨네요. 클라이언트 컴포넌트와 서버 컴포넌트의 사전 렌더링 방식이 조금 다르기 때문에 혼란스러울 수 있습니다.

클라이언트 컴포넌트의 렌더링

  • 클라이언트 컴포넌트는 사전 렌더링 과정에서 HTML로 변환되지 않고, 기본적으로는 placeholder와 같은 비어 있는 div로 서버에서 전송됩니다.
  • 그것은 브라우저가 클라이언트 측에서 JavaScript로 하이드레이션 과정 중에 전체 DOM 구조를 완성합니다. 즉, 실제 콘텐츠는 클라이언트에서 JavaScript에 의해 만들어지죠.
  • “사전 렌더링”이라는 용어는 일반적으로 서버에서 HTML을 미리 생성하는 것을 의미하지만, 클라이언트 컴포넌트의 경우 서버는 이를 HTML로 미리 렌더링하지 않습니다. 대신에 서버와 클라이언트 간에 필요한 정보를 전송하여 클라이언트에서 최종 렌더링이 이루어집니다.

관련해서 더 자세한 이해를 돕기 위해 유사한 질문들이 다루어진 URL을 참고하시면 도움이 될 것 같습니다:

저는 질문자님의 이해를 돕고자 지식공유자님의 기존 답변을 참고하여 유사한 답변 링크를 추천해드리고 있습니다.
현재 베타 기능으로 답변이 만족스럽지 않을 수 있는 점 양해 부탁드립니다. 🙏
추가적으로 궁금한 점이 있으시면, 이어서 질문해 주세요. 곧 지식공유자께서 답변해 주실 것입니다.

rehype-sanitize 설치의 필요성

0

92

2

Notion API-DB 연결이 안돼요

0

540

2

private folders 와 전역 폴더

0

70

2

퀴즈 질문 풀이 오류

0

86

2

Streaming 관련해서 문의드립니다.

0

74

2

ISR 매커니즘에 대한 궁금증

0

68

2

cursor AI 프로젝트 룰 관련 질문 드립니다.

0

344

2

params 에 Promise 객체 타입이 지정되어야 하는 이유? 최신?

0

76

1

streaming 페이지 보완 필요

1

56

2

remark-gfm

0

111

2

마크업 파트 가독성 향상 방법

0

63

2

Next.js 블로그 결과물 공유 이벤트 진행 여부

0

69

1

블로그 PostCard 이미지 상단 여백

0

70

3

flex-col 과 space-y-6 차이

0

118

1

컴파일 에러 및 의존성 충돌 문제

0

106

2

TypeError: Invalid URL

0

172

2

세션 6의 퀴즈 5번 정답 옵셔널 캐치올 아닌가요?

1

73

2

상세 페이지 404 에러 발생

0

113

2

스타일이 적용 안되는 문제

0

96

2

cursorAI에 rule 생성 시 rule type이 안 나오는 현상 발생

0

177

3

상세페이지 구현 Author의 name 프러퍼티가 조회가 안됩니다.

1

71

2

A

0

94

2

unstable_cache 사용 시 적정 revalidate 값 문의

0

91

2

useActionState에서 반환값 필드 생략 시 조건에 따라 에러 발생 여부가 다른 이유

0

85

2