preloadModule - This feature is available in the latest Canary

Canary

preloadModule는 현재 React의 카나리(Canary) 버전 및 실험 채널에서만 사용할 수 있습니다. 여기에서 React의 릴리즈 채널에 대해 자세히 알아보세요.

중요합니다!

React 기반 프레임워크는 리소스 로딩을 대신 처리하는 경우가 많으므로 이 API를 직접 호출할 필요가 없을 수도 있습니다. 자세한 내용은 해당 프레임워크의 문서를 참조하세요.

preloadModule을 사용하면 사용할 ESM 모듈을 미리 가져올 수 있습니다.

preloadModule("https://example.com/module.js", {as: "script"});

레퍼런스

preloadModule(href, options)

ESM 모듈을 미리 불러오려면 react-dom에서 preloadModule 함수를 호출합니다.

import { preloadModule } from 'react-dom';

function AppRoot() {
preloadModule("https://example.com/module.js", {as: "script"});
// ...
}

아래에서 더 많은 예시를 확인하세요.

preloadModule 기능은 브라우저에 주어진 모듈 다운로드를 시작해야 한다는 힌트를 제공하여 시간을 절약할 수 있습니다.

매개변수

  • href: 문자열입니다. 다운로드하려는 모듈의 URL입니다.
  • options: 객체입니다. 여기에는 다음과 같은 속성들이 포함되어 있습니다.
    • as: 필수 문자열입니다. 'script'여야 합니다.
    • crossOrigin: 문자열입니다. 사용할 CORS 정책입니다. 가능한 값은 anonymoususe-credentials입니다.
    • integrity: 문자열입니다. 모듈의 신뢰성 확인을 위한 모듈의 암호화 해시입니다.
    • nonce: 문자열입니다. 엄격한 컨텐츠 보안 정책을 사용할 때 모듈을 허용하기 위한 암호화 논스(Nonce)입니다.

반환값

preloadModule는 아무것도 반환하지 않습니다.

주의 사항

  • 동일한 hrefpreloadModule을 여러 번 호출하는 것은 한 번 호출하는 것과 동일한 효과가 있습니다.
  • 브라우저에서는 컴포넌트를 렌더링하는 중이거나, Effect, 이벤트 핸들러 등 어떤 상황에서도 preloadModule을 호출할 수 있습니다.
  • 서버 측 렌더링이나 서버 컴포넌트를 렌더링할 때, preloadModule은 컴포넌트를 렌더링하는 동안 호출하거나, 컴포넌트 렌더링에서 시작된 비동기 컨텍스트 내에서 호출할 때만 효과가 있습니다. 그 외의 호출은 무시됩니다.

사용법

렌더링 시 미리 불러오기

컴포넌트 또는 그 자식 컴포넌트가 특정 모듈을 사용한다는 것을 알고 있다면, 컴포넌트를 렌더링할 때 preloadModule을 호출하세요.

import { preloadModule } from 'react-dom';

function AppRoot() {
preloadModule("https://example.com/module.js", {as: "script"});
return ...;
}

브라우저에서 모듈을 즉시 실행하려면(단순히 다운로드하는 것 대신) preinitModule을 대신 사용하세요. ESM 모듈이 아닌 스크립트를 로드하려면 preload를 사용하세요.

이벤트 핸들러에서 미리 불러오기

모듈이 필요한 페이지나 State를 전환되기 전에 이벤트 핸들러에서 preloadModule을 호출하세요. 이렇게 하면 새로운 페이지나 State를 렌더링할 때 호출하는 것보다 더 일찍 프로세스를 시작할 수 있습니다.

import { preloadModule } from 'react-dom';

function CallToAction() {
const onClick = () => {
preloadModule("https://example.com/module.js", {as: "script"});
startWizard();
}
return (
<button onClick={onClick}>Start Wizard</button>
);
}