Skip to content

Latest commit

 

History

History
171 lines (115 loc) · 7.46 KB

File metadata and controls

171 lines (115 loc) · 7.46 KB
title preload
canary true

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

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

preload를 사용하면 사용할 스타일시트, 글꼴 또는 외부 스크립트와 같은 리소스를 미리 가져올 수 있습니다.

preload("https://example.com/font.woff2", {as: "font"});

레퍼런스 {/reference/}

preload(href, options) {/preload/}

리소스를 미리 로드하려면 react-dom에서 preload 함수를 호출합니다.

import { preload } from 'react-dom';

function AppRoot() {
  preload("https://example.com/font.woff2", {as: "font"});
  // ...
}

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

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

매개변수 {/parameters/}

  • href: 문자열입니다. 다운로드하려는 리소스의 URL입니다.
  • options: 객체입니다. 여기에는 다음과 같은 속성이 포함되어 있습니다:
    • as: 필수 문자열입니다. 리소스의 타입입니다. 가능한 값audio, document, embed, fetch, font, image, object, script, style, track, video, worker입니다.
    • crossOrigin: 문자열입니다. 사용할 CORS 정책입니다. 가능한 값은 anonymoususe-credentials입니다. as"fetch"로 설정된 경우 필수입니다.
    • referrerPolicy: 문자열입니다. 페칭할 때 전송할 Referrer 헤더입니다. 사용할 수 있는 값은 no-referrer-when-downgrade (기본값), no-referrer, origin, origin-when-cross-origin 그리고 unsafe-url입니다.
    • integrity: 문자열입니다. 리소스의 진위 확인을 위한 리소스의 암호화 해시입니다.
    • type: 문자열입니다. 리소스의 MIME 타입입니다.
    • nonce: 문자열입니다. 엄격한 콘텐츠 보안 정책을 사용할 때 리소스를 허용하기 위한 암호화 논스입니다.
    • fetchPriority: 문자열입니다. 리소스 페칭의 상대적 우선순위를 제안합니다. 사용할 수 있는 값은 auto (기본값), high 그리고 low입니다.
    • imageSrcSet: 문자열입니다. as: "image"와만 함께 사용합니다. 이미지의 소스 세트를 지정합니다.
    • imageSizes: 문자열입니다. as: "image"와만 함께 사용합니다. 이미지의 크기를 지정합니다.

반환값 {/returns/}

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

주의 사항 {/caveats/}

  • preload에 대한 여러 번의 동등한 호출은 한 번의 호출과 동일한 효과를 갖습니다. preload에 대한 호출은 다음 규칙에 따라 동등한 것으로 간주합니다:
    • 다음의 경우를 제외하고 두 호출의 href가 같으면 두 호출은 동일합니다:
    • asimage로 설정된 경우 두 호출의 href, imageSrcSetimageSizes가 같으면 두 호출은 동일합니다.
  • 브라우저에서는 컴포넌트 렌더링 중, Effect, 이벤트 핸들러 등 어떤 상황에서도 preload를 호출할 수 있습니다.
  • 서버 사이드 렌더링 또는 서버 컴포넌트를 렌더링할 때 preload는 컴포넌트를 렌더링하는 동안 또는 컴포넌트 렌더링에서 발생하는 비동기 context에서 호출하는 경우에만 영향을 미칩니다. 다른 호출은 무시됩니다.

사용법 {/usage/}

렌더링 시 프리로딩 {/preloading-when-rendering/}

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

외부 스크립트 프리로드하기 {/preloading-an-external-script/}

import { preload } from 'react-dom';

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

브라우저에서 스크립트 실행을 즉시 시작하려면(스크립트를 다운로드하는 대신) preinit을 대신 사용하세요. ESM 모듈을 로드하려면 preloadModule을 사용하세요.

스타일시트 프리로드하기 {/preloading-a-stylesheet/}

import { preload } from 'react-dom';

function AppRoot() {
  preload("https://example.com/style.css", {as: "style"});
  return ...;
}

스타일시트를 문서에 즉시 삽입하려면(즉, 브라우저가 다운로드하는 대신 즉시 구문 분석을 시작한다는 의미) preinit을 대신 사용하세요.

글꼴 프리로드하기 {/preloading-a-font/}

import { preload } from 'react-dom';

function AppRoot() {
  preload("https://example.com/style.css", {as: "style"});
  preload("https://example.com/font.woff2", {as: "font"});
  return ...;
}

스타일시트를 프리로드하는 경우 스타일시트가 참조하는 모든 글꼴도 프리로드하는 것이 좋습니다. 이렇게 하면 브라우저가 스타일시트를 다운로드하고 구문 분석하기 전에 글꼴 다운로드를 시작할 수 있습니다.

이미지 프리로드하기 {/preloading-an-image/}

import { preload } from 'react-dom';

function AppRoot() {
  preload("/banner.png", {
    as: "image",
    imageSrcSet: "/banner512.png 512w, /banner1024.png 1024w",
    imageSizes: "(max-width: 512px) 512px, 1024px",
  });
  return ...;
}

이미지를 프리로드할 때 imageSrcSetimageSizes 옵션은 브라우저가 화면 크기에 맞는 올바른 크기의 이미지를 가져오는 데 도움이 됩니다.

이벤트 핸들러에서 프리로드하기 {/preloading-in-an-event-handler/}

외부 리소스가 필요한 페이지나 state로 전환하기 전에 이벤트 핸들러에서 preload를 호출하세요. 이렇게 하면 새 페이지나 state를 렌더링하는 동안 호출하는 것보다 프로세스가 더 빨리 시작됩니다.

import { preload } from 'react-dom';

function CallToAction() {
  const onClick = () => {
    preload("https://example.com/wizardStyles.css", {as: "style"});
    startWizard();
  }
  return (
    <button onClick={onClick}>Start Wizard</button>
  );
}