폰트
이 API 참조는 next/font/google
와 next/font/local
을 사용하는 방법을 이해하는 데 도움이 될 것입니다. 기능과 사용법에 대해서는 폰트 최적화 페이지를 참조하세요.
폰트 함수 인수
키 | font/google | font/local | 타입 | 필수 |
---|---|---|---|---|
src | ❌ | ✔️ | 문자열 또는 객체 배열 | 예 |
weight | ✔️ | ✔️ | 문자열 또는 배열 | 필수/선택 |
style | ✔️ | ✔️ | 문자열 또는 배열 | - |
subsets | ✔️ | ❌ | 문자열 배열 | - |
axes | ✔️ | ❌ | 문자열 배열 | - |
display | ✔️ | ✔️ | 문자열 | - |
preload | ✔️ | ✔️ | 불리언 | - |
fallback | ✔️ | ✔️ | 문자열 배열 | - |
adjustFontFallback | ✔️ | ✔️ | 불리언 또는 문자열 | - |
variable | ✔️ | ✔️ | 문자열 | - |
declarations | ❌ | ✔️ | 객체 배열 | - |
src
폰트 로더 함수가 호출되는 디렉토리를 기준으로 한 폰트 파일의 경로를 문자열 또는 객체 배열(타입 Array<{path: string, weight?: string, style?: string}>
)로 나타냅니다.
next/font/local
에서 사용됨
- 필수
예시:
src:'./fonts/my-font.woff2'
:my-font.woff2
가app
디렉토리 내의fonts
라는 디렉토리에 위치한 경우src:[{path: './inter/Inter-Thin.ttf', weight: '100',},{path: './inter/Inter-Regular.ttf',weight: '400',},{path: './inter/Inter-Bold-Italic.ttf', weight: '700',style: 'italic',},]
- 폰트 로더 함수가
app/page.tsx
에서src:'../styles/fonts/my-font.ttf'
로 호출되는 경우,my-font.ttf
는 프로젝트 루트의styles/fonts
에 위치합니다
weight
폰트 weight
는 다음과 같은 옵션을 제공합니다:
- 특정 폰트에 대해 사용 가능한 가중치의 값들 또는 가변 폰트인 경우 값의 범위를 나타내는 문자열
- 폰트가 가변 Google 폰트가 아닌 경우 가중치 값의 배열. 이는
next/font/google
에만 적용됩니다.
next/font/google
와 next/font/local
에서 사용됨
- 사용하는 폰트가 가변이 아닌 경우 필수
예시:
weight: '400'
: 단일 가중치 값에 대한 문자열 -Inter
폰트의 경우, 가능한 값은'100'
,'200'
,'300'
,'400'
,'500'
,'600'
,'700'
,'800'
,'900'
또는'variable'
입니다 ('variable'
이 기본값)weight: '100 900'
: 가변 폰트에 대한100
에서900
사이의 범위를 나타내는 문자열weight: ['100','400','900']
: 가변이 아닌 폰트에 대한 3개의 가능한 값의 배열
style
폰트 style
은 다음과 같은 옵션을 제공합니다:
- 기본값이
'normal'
인 문자열 값 - 폰트가 가변 Google 폰트가 아닌 경우 스타일 값의 배열. 이는
next/font/google
에만 적용됩니다.
next/font/google
와 next/font/local
에서 사용됨
- 선택 사항
예시:
style: 'italic'
: 문자열 -next/font/google
의 경우normal
또는italic
일 수 있습니다style: 'oblique'
: 문자열 -next/font/local
의 경우 어떤 값이든 가능하지만 표준 폰트 스타일에서 가져올 것으로 예상됩니다style: ['italic','normal']
:next/font/google
에 대한 2개의 값의 배열 - 값은normal
과italic
중에서 선택됩니다
subsets
폰트 subsets
는 프리로드하고 싶은 각 서브셋의 이름을 포함하는 문자열 배열로 정의됩니다. subsets
를 통해 지정된 폰트는 preload
옵션이 true일 때(기본값) 헤드에 링크 프리로드 태그가 삽입됩니다.
next/font/google
에서 사용됨
- 선택 사항
예시:
subsets: ['latin']
: 서브셋latin
을 포함하는 배열
모든 서브셋 목록은 사용하는 폰트의 Google Fonts 페이지에서 찾을 수 있습니다.
axes
일부 가변 폰트에는 포함할 수 있는 추가 axes
가 있습니다. 기본적으로 파일 크기를 줄이기 위해 폰트 가중치만 포함됩니다. axes
의 가능한 값은 특정 폰트에 따라 다릅니다.
next/font/google
에서 사용됨
- 선택 사항
예시:
axes: ['slnt']
:Inter
가변 폰트에 대한slnt
값을 포함하는 배열.Inter
는 여기에 표시된 대로 추가axes
로slnt
를 가집니다. 폰트의 가능한axes
값은 Google 가변 폰트 페이지의 필터를 사용하여 찾을 수 있으며,wght
이외의 축을 찾아보세요.
display
폰트 display
는 'auto'
, 'block'
, 'swap'
, 'fallback'
또는 'optional'
의 가능한 문자열 값을 가지며 기본값은 'swap'
입니다.
next/font/google
와 next/font/local
에서 사용됨
- 선택 사항
예시:
display: 'optional'
:optional
값이 할당된 문자열
preload
폰트를 미리 불러와야 하는지 여부를 지정하는 불리언 값입니다. 기본값은 true
입니다.
next/font/google
와 next/font/local
에서 사용됨
- 선택 사항
예시:
preload: false
fallback
폰트를 로드할 수 없는 경우 사용할 대체 폰트입니다. 기본값이 없는 대체 폰트의 문자열 배열입니다.
- 선택 사항
next/font/google
와 next/font/local
에서 사용됨
예시:
fallback: ['system-ui', 'arial']
: 대체 폰트를system-ui
또는arial
로 설정하는 배열
adjustFontFallback
next/font/google
의 경우: Cumulative Layout Shift를 줄이기 위해 자동 대체 폰트를 사용할지 여부를 설정하는 불리언 값입니다. 기본값은true
입니다.next/font/local
의 경우: Cumulative Layout Shift를 줄이기 위해 자동 대체 폰트를 사용할지 여부를 설정하는 문자열 또는 불리언false
값입니다. 가능한 값은'Arial'
,'Times New Roman'
또는false
입니다. 기본값은'Arial'
입니다.
next/font/google
와 next/font/local
에서 사용됨
- 선택 사항
예시:
adjustFontFallback: false
:next/font/google
의 경우adjustFontFallback: 'Times New Roman'
:next/font/local
의 경우
variable
스타일이 CSS 변수 방법으로 적용되는 경우 사용할 CSS 변수 이름을 정의하는 문자열 값입니다.
next/font/google
와 next/font/local
에서 사용됨
- 선택 사항
예시:
variable: '--my-font'
: CSS 변수--my-font
가 선언됩니다
declarations
생성된 @font-face
를 더 정의하는 font-face descriptor 키-값 쌍의 배열입니다.
next/font/local
에서 사용됨
- 선택 사항
예시:
declarations: [{ prop: 'ascent-override', value: '90%' }]
스타일 적용하기
폰트 스타일을 세 가지 방법으로 적용할 수 있습니다:
className
로드된 폰트에 대한 읽기 전용 CSS className
을 HTML 요소에 전달하기 위해 반환합니다.
<p className={inter.className}>안녕하세요, Next.js!</p>
style
로드된 폰트에 대한 읽기 전용 CSS style
객체를 HTML 요소에 전달하기 위해 반환합니다. 여기에는 폰트 패밀리 이름과 대체 폰트에 접근하기 위한 style.fontFamily
가 포함됩니다.
<p style={inter.style}>Hello World</p>
CSS 변수
외부 스타일 시트에서 스타일을 설정하고 추가 옵션을 지정하려면 CSS 변수 방법을 사용하세요.
폰트를 가져오는 것 외에도 CSS 변수가 정의된 CSS 파일을 가져오고 폰트 로더 객체의 변수 옵션을 다음과 같이 설정합니다:
import { Inter } from "next/font/google";
import styles from "../styles/component.module.css";
const inter = Inter({
variable: "--font-inter",
});
import { Inter } from "next/font/google";
import styles from "../styles/component.module.css";
const inter = Inter({
variable: "--font-inter",
});
폰트를 사용하려면 스타일을 적용하려는 텍스트의 부모 컨테이너의 className
을 폰트 로더의 variable
값으로 설정하고 텍스트의 className
을 외부 CSS 파일의 styles
속성으로 설정합니다.
<main className={inter.variable}>
<p className={styles.text}>Hello World</p>
</main>
<main className={inter.variable}>
<p className={styles.text}>Hello World</p>
</main>
component.module.css
CSS 파일에서 text
선택자 클래스를 다음과 같이 정의합니다:
.text {
font-family: var(--font-inter);
font-weight: 200;
font-style: italic;
}
위의 예에서 Hello World
텍스트는 Inter
폰트와 생성된 폰트 대체를 사용하여 font-weight: 200
과 font-style: italic
로 스타일링됩니다.
폰트 정의 파일 사용하기
localFont
또는 Google 폰트 함수를 호출할 때마다 해당 폰트는 애플리케이션에서 하나의 인스턴스로 호스팅됩니다. 따라서 여러 곳에서 동일한 폰트를 사용해야 하는 경우, 한 곳에서 로드하고 필요한 곳에서 관련 폰트 객체를 가져와야 합니다. 이는 폰트 정의 파일을 사용하여 수행됩니다.
예를 들어, app 디렉토리의 루트에 있는 styles
폴더에 fonts.ts
파일을 만듭니다.
그런 다음 폰트 정의를 다음과 같이 지정합니다:
import { Inter, Lora, Source_Sans_3 } from "next/font/google";
import localFont from "next/font/local";
// 가변 폰트 정의
const inter = Inter();
const lora = Lora();
// 비가변 폰트의 2가지 가중치 정의
const sourceCodePro400 = Source_Sans_3({ weight: "400" });
const sourceCodePro700 = Source_Sans_3({ weight: "700" });
// styles 폴더에 저장된 GreatVibes-Regular.ttf의 사용자 정의 로컬 폰트 정의
const greatVibes = localFont({ src: "./GreatVibes-Regular.ttf" });
export { inter, lora, sourceCodePro400, sourceCodePro700, greatVibes };
import { Inter, Lora, Source_Sans_3 } from "next/font/google";
import localFont from "next/font/local";
// 가변 폰트 정의
const inter = Inter();
const lora = Lora();
// 비가변 폰트의 2가지 가중치 정의
const sourceCodePro400 = Source_Sans_3({ weight: "400" });
const sourceCodePro700 = Source_Sans_3({ weight: "700" });
// styles 폴더에 저장된 GreatVibes-Regular.ttf의 사용자 정의 로컬 폰트 정의
const greatVibes = localFont({ src: "./GreatVibes-Regular.ttf" });
export { inter, lora, sourceCodePro400, sourceCodePro700, greatVibes };
이제 코드에서 다음과 같이 이러한 정의를 사용할 수 있습니다:
import { inter, lora, sourceCodePro700, greatVibes } from "../styles/fonts";
export default function Page() {
return (
<div>
<p className={inter.className}>Inter 폰트를 사용한 Hello world</p>
<p style={lora.style}>Lora 폰트를 사용한 Hello world</p>
<p className={sourceCodePro700.className}>
가중치 700의 Source_Sans_3 폰트를 사용한 Hello world
</p>
<p className={greatVibes.className}>Great Vibes 폰트의 내 제목</p>
</div>
);
}
import { inter, lora, sourceCodePro700, greatVibes } from "../styles/fonts";
export default function Page() {
return (
<div>
<p className={inter.className}>Inter 폰트를 사용한 Hello world</p>
<p style={lora.style}>Lora 폰트를 사용한 Hello world</p>
<p className={sourceCodePro700.className}>
가중치 700의 Source_Sans_3 폰트를 사용한 Hello world
</p>
<p className={greatVibes.className}>Great Vibes 폰트의 내 제목</p>
</div>
);
}
코드에서 폰트 정의에 더 쉽게 접근할 수 있도록 tsconfig.json
또는 jsconfig.json
파일에 경로 별칭을 다음과 같이 정의할 수 있습니다:
{
"compilerOptions": {
"paths": {
"@/fonts": ["./styles/fonts"]
}
}
}
이제 다음과 같이 모든 폰트 정의를 가져올 수 있습니다:
import { greatVibes, sourceCodePro400 } from "@/fonts";
import { greatVibes, sourceCodePro400 } from "@/fonts";
버전 변경
버전 | 변경 사항 |
---|---|
v13.2.0 | @next/font 가 next/font 로 이름 변경됨. 설치가 더 이상 필요 없음. |
v13.0.0 | @next/font 추가됨. |