renderToNodeStream
은 React 트리를 Node.js Readable Stream.으로 렌더링합니다.
const stream = renderToNodeStream(reactNode, options?)
레퍼런스
renderToNodeStream(reactNode, options?)
서버에서 renderToNodeStream
을 호출하여 응답으로 연결할 수 있는 Node.js Readable Stream을 가져옵니다.
import { renderToNodeStream } from 'react-dom/server';
const stream = renderToNodeStream(<App />)
stream.pipe(response);
클라이언트에서 hydrateRoot
를 호출하여 서버에서 생성된 HTML을 상호작용 가능하도록 만드세요.
매개변수
reactNode
: HTML로 렌더링하려는 React 노드입니다. 예를 들어,<App />
과 같은 JSX 엘리먼트입니다.- optional
options
: 서버 렌더링을 위한 객체입니다.- optional
identifierPrefix
:useId
.에 의해 생성된 ID에 대해 React가 사용하는 문자열 접두사입니다. 같은 페이지에서 여러 루트를 사용할 때 충돌을 피하기 위해 유용합니다.hydrateRoot
.에 전달된 접두사와 동일해야 합니다.
- optional
반환값
HTML 문자열을 출력하는 Node.js Readable Stream를 반환합니다.
주의 사항
-
이 메서드는 출력물을 반환하기 전에 모든 Suspense boundaries)가 완료될 때까지 대기합니다.
-
React 18부터 이 메서드는 모든 출력값을 버퍼링하므로 실제로 스트리밍 이점을 제공하지 않습니다. 따라서
renderToPipeableStream
으로 마이그레이션할 것을 권장합니다. -
반환된 스트림은 utf-8로 인코딩된 바이트 스트림입니다. 다른 인코딩 스트림이 필요한 경우 텍스트 변환을 위한 변환 스트림을 제공하는 iconv-lite와 같은 프로젝트를 살펴보세요.
사용법
React 트리를 HTML로 Node.js Readable Stream에 렌더링하기
renderToNodeStream
을 호출하여 서버 응답으로 연결할 수 있는 Node.js Readable Stream을 가져옵니다.
import { renderToNodeStream } from 'react-dom/server';
// 라우트 핸들러 구문은 백엔드 프레임워크에 따라 다릅니다.
app.use('/', (request, response) => {
const stream = renderToNodeStream(<App />);
stream.pipe(response);
});
스트림은 React 컴포넌트의 초기에 상호작용하지 않는 HTML 출력을 생성합니다. 클라이언트에서 서버에서 생성된 HTML을 hydrate 처리하고 상호작용하도록 하려면 hydrateRoot
를 호출해야 합니다.