renderToNodeStream

더 이상 사용되지 않습니다

이 API는 향후 React의 주요 버전에서 제거될 예정입니다. 대신 renderToPipeableStream을 사용하세요.

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.에 전달된 접두사와 동일해야 합니다.

반환

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를 호출해야 합니다.