Core Web Vitals에 맞게 웹 글꼴을 최적화합니다.
이 도움말에서는 글꼴의 성능 권장사항을 설명합니다. 웹 글꼴은 다음과 같이 다양한 방식으로 성능에 영향을 미칩니다.
- 지연된 텍스트 렌더링: 웹 글꼴이 로드되지 않으면 일반적으로 브라우저는 텍스트 렌더링을 지연시킵니다. 대부분의 경우 이로 인해 콘텐츠가 포함된 첫 페인트(FCP)가 지연됩니다. 경우에 따라 최대 콘텐츠 렌더링 시간(LCP)이 지연될 수 있습니다.
- 레이아웃 변경: 글꼴 교체는 레이아웃 변경을 야기할 수 있으며 이로 인해 레이아웃 변경 횟수 (CLS)에 영향을 미칠 수 있습니다. 이러한 레이아웃 전환은 웹 글꼴과 대체 글꼴이 페이지에서 서로 다른 양의 공간을 차지할 때 발생합니다.
이 도움말은 글꼴 로드, 글꼴 게재, 글꼴 렌더링의 세 섹션으로 나뉘어 있습니다. 각 섹션에서는 글꼴 수명 주기의 특정 측면이 작동하는 방식을 설명하고 이에 상응하는 권장사항을 제공합니다.
글꼴 로드
글꼴은 일반적으로 중요한 리소스입니다. 글꼴이 없으면 사용자가 페이지 콘텐츠를 볼 수 없기 때문입니다. 따라서 글꼴 로드 권장사항은 일반적으로 글꼴이 최대한 빨리 로드되도록 하는 데 중점을 둡니다. 타사 사이트에서 로드된 글꼴은 특별히 주의해야 합니다. 이러한 글꼴 파일을 다운로드하려면 별도의 연결 설정이 필요하기 때문입니다.
페이지의 글꼴이 제때 요청되는지 확실하지 않다면 Chrome DevTools의 네트워크 패널 내 타이밍 탭에서 자세한 내용을 확인하세요.
@font-face
이해하기
글꼴 로드 권장사항을 살펴보기 전에 @font-face
의 작동 방식과 글꼴 로드에 미치는 영향을 이해하는 것이 중요합니다.
@font-face
선언은 웹 글꼴을 사용할 때 필수적인 부분입니다. 최소한 글꼴을 참조하는 데 사용될 이름을 선언하고 해당 글꼴 파일의 위치를 나타냅니다.
@font-face {
font-family: "Open Sans";
src: url("/fonts/OpenSans-Regular-webfont.woff2") format("woff2");
}
@font-face
선언이 발생하면 글꼴이 요청된다는 일반적인 오해가 있습니다. 이는 사실이 아닙니다. @font-face
선언 자체로는 글꼴 다운로드가 트리거되지 않습니다. 페이지에서 사용된 스타일 지정을 통해 참조되는 경우에만 글꼴이 다운로드됩니다. 예를 들어 다음과 같습니다.
@font-face {
font-family: "Open Sans";
src: url("/fonts/OpenSans-Regular-webfont.woff2") format("woff2");
}
h1 {
font-family: "Open Sans"
}
즉, 위의 예에서 Open Sans
는 페이지에 <h1>
요소가 포함된 경우에만 다운로드됩니다.
따라서 글꼴 최적화를 고려할 때는 글꼴 파일 자체만큼이나 스타일시트도 고려해야 합니다. 스타일시트의 콘텐츠나 전달 방식을 변경하면 글꼴이 제공되는 시점에 상당한 영향을 미칠 수 있습니다. 마찬가지로 사용되지 않는 CSS를 삭제하고 스타일시트를 분할하면 페이지에서 로드하는 글꼴 수를 줄일 수 있습니다.
인라인 글꼴 선언
대부분의 사이트는 글꼴 선언 및 기타 중요한 스타일을 외부 스타일시트에 포함하는 대신 기본 문서의 <head>
에 인라인으로 추가하는 것이 좋습니다. 이렇게 하면 브라우저가 외부 스타일시트가 다운로드될 때까지 기다릴 필요가 없으므로 브라우저가 글꼴 선언을 더 빨리 찾을 수 있습니다.
<head>
<style>
@font-face {
font-family: "Open Sans";
src: url("/fonts/OpenSans-Regular-webfont.woff2") format("woff2");
}
body {
font-family: "Open Sans";
}
...etc.
</style>
</head>
중요한 CSS를 인라인 처리하는 것은 모든 사이트에서 실행할 수 있는 것은 아닌 고급 기법일 수 있습니다. 성능 이점은 분명하지만, 필수 CSS(가급적 중요한 CSS만)가 올바르게 인라인 처리되고 추가 CSS가 렌더링을 차단하지 않는 방식으로 전송되도록 하려면 추가 프로세스와 빌드 도구가 필요합니다.
중요한 서드 파티 출처 사전 연결
사이트에서 서드 파티 사이트의 글꼴을 로드하는 경우 preconnect
리소스 힌트를 사용하여 서드 파티 출처와의 조기 연결을 설정하는 것이 좋습니다. 리소스 힌트는 문서의 <head>
에 배치해야 합니다. 아래 리소스 힌트는 글꼴 스타일시트를 로드하기 위한 연결을 설정합니다.
<head>
<link rel="preconnect" href="https://fonts.com">
</head>
글꼴 파일을 다운로드하는 데 사용되는 연결을 미리 연결하려면 crossorigin
속성을 사용하는 별도의 preconnect
리소스 힌트를 추가합니다. 스타일시트와 달리 글꼴 파일은 CORS 연결을 통해 전송해야 합니다.
<head>
<link rel="preconnect" href="https://fonts.com">
<link rel="preconnect" href="https://fonts.com" crossorigin>
</head>
preconnect
리소스 힌트를 사용할 때 글꼴 제공업체가 별도의 출처에서 스타일시트와 글꼴을 제공할 수 있다는 점에 유의하세요. 예를 들어 다음과 같이 preconnect
리소스 힌트가 Google Fonts에 사용됩니다.
<head>
<link rel="preconnect" href="https://fonts.googleapis.com">
<link rel="preconnect" href="https://fonts.gstatic.com" crossorigin>
</head>
preload
를 사용하여 글꼴을 로드할 때 주의하세요.
preload
는 페이지 로드 프로세스 초기에 글꼴을 검색 가능하도록 만드는 데 매우 효과적이지만, 다른 리소스 로드에서 브라우저 리소스를 가져가는 비용이 발생합니다.
글꼴 선언을 삽입하고 스타일시트를 조정하는 것이 더 효과적인 방법일 수 있습니다. 이러한 조정은 단순히 해결 방법을 제공하는 대신 늦게 발견된 글꼴의 근본 원인을 해결하는 데 더 가까워집니다.
또한 preload
를 글꼴 로드 전략으로 사용하면 브라우저에 내장된 일부 콘텐츠 협상 전략을 우회하므로 신중하게 사용해야 합니다. 예를 들어 preload
는 unicode-range
선언을 무시하며, 신중하게 사용한다면 단일 글꼴 형식을 로드하는 데만 사용해야 합니다.
그러나 외부 스타일시트를 사용하는 경우 브라우저가 글꼴이 필요한지 훨씬 나중에야 알 수 있으므로 가장 중요한 글꼴을 미리 로드하는 것이 매우 효과적일 수 있습니다.
글꼴 제공
글꼴을 더 빠르게 전송하면 텍스트 렌더링 속도가 빨라집니다. 또한 글꼴이 충분히 일찍 전송되면 글꼴 전환으로 인한 레이아웃 전환을 제거하는 데 도움이 될 수 있습니다.
자체 호스팅 글꼴 사용
서드 파티 연결 설정이 필요하지 않으므로 자체 호스팅 글꼴을 사용하면 더 나은 성능을 얻을 수 있습니다. 하지만 실제로 이러한 두 옵션의 성능 차이는 덜 명확합니다. 예를 들어 Web Almanac에 따르면 타사 글꼴을 사용하는 사이트가 자사 글꼴을 사용하는 글꼴보다 렌더링 속도가 빠릅니다.
자체 호스팅 글꼴을 사용하려는 경우 사이트에서 콘텐츠 전송 네트워크(CDN) 및 HTTP/2를 사용하고 있는지 확인하세요. 이러한 기술을 사용하지 않으면 자체 호스팅 글꼴이 더 나은 성능을 제공할 가능성이 훨씬 낮습니다. 자세한 내용은 콘텐츠 전송 네트워크를 참고하세요.
자체 호스팅 글꼴을 사용하는 경우 서드 파티 글꼴 제공업체에서 일반적으로 자동으로 제공하는 글꼴 파일 최적화(예: 글꼴 하위 집합 및 WOFF2 압축)도 적용하는 것이 좋습니다. 이러한 최적화를 적용하는 데 필요한 노력의 양은 사이트에서 지원하는 언어에 따라 다릅니다. 특히 CJK 언어용 글꼴을 최적화하는 것은 특히 어려울 수 있습니다.
WOFF2 사용
최신 글꼴 글꼴 중에서 WOFF2가 가장 최신 글꼴로 브라우저 지원 폭이 가장 넓고 압축률도 가장 높습니다. Brotli를 사용하므로 WOFF2는 WOFF보다 30% 더 효과적으로 압축되므로 다운로드할 데이터가 줄어 성능이 향상됩니다.
브라우저 지원을 감안할 때 전문가들은 이제 WOFF2만 사용할 것을 권장합니다.
사실 이제는 WOFF2만 사용하고 다른 것은 모두 잊어버리라고 선언할 때도 되었습니다.
브램 스타인, 2022년 웹 연감
이렇게 하면 CSS와 워크플로가 대폭 간소화되고 실수로 글꼴을 두 번 다운로드하거나 잘못된 글꼴을 다운로드하는 일이 방지됩니다. 이제 WOFF2가 모든 위치에서 지원됩니다. 따라서 아주 오래된 브라우저를 지원해야 하는 경우가 아니라면 WOFF2를 사용하세요. 웹 글꼴을 제공할 수 없다면 이전 브라우저에 웹 글꼴을 제공하지 않는 것이 좋습니다. 강력한 대체 전략이 마련되어 있다면 문제가 되지 않습니다. 이전 브라우저를 사용하는 방문자는 대체 글꼴만 볼 수 있습니다.
하위 집합 글꼴
글꼴 파일에는 일반적으로 지원하는 다양한 문자의 글리프가 많이 포함되어 있습니다. 하지만 페이지에 모든 문자가 필요하지는 않으며 글꼴을 하위 집합으로 만들어 글꼴 파일의 크기를 줄일 수 있습니다.
@font-face
선언의 unicode-range
설명자는 브라우저에 글꼴을 사용할 수 있는 문자를 알려줍니다.
@font-face {
font-family: "Open Sans";
src: url("/fonts/OpenSans-Regular-webfont.woff2") format("woff2");
unicode-range: U+0025-00FF;
}
페이지에 유니코드 범위에 해당하는 문자가 하나 이상 포함된 경우 글꼴 파일이 다운로드됩니다. unicode-range
는 일반적으로 페이지 콘텐츠에 사용된 언어에 따라 다른 글꼴 파일을 제공하는 데 사용됩니다.
unicode-range
는 하위 집합 생성 기법과 함께 사용되는 경우가 많습니다. 하위 집합 글꼴에는 원본 글꼴 파일에 포함된 글리프 중 일부가 포함됩니다. 예를 들어 사이트에서 모든 사용자에게 모든 문자를 제공하는 대신 라틴어와 키릴 문자를 위한 별도의 하위 집합 글꼴을 생성할 수 있습니다. 글꼴당 글리프 수는 매우 다양합니다. 라틴어 글꼴은 일반적으로 글꼴당 100~1,000개의 글리프를 포함하며, CJK 글꼴은 10,000자 이상의 문자를 포함할 수 있습니다. 사용하지 않는 글리프를 제거하면 글꼴의 파일 크기가 크게 줄어들 수 있습니다.
일부 글꼴 제공업체는 서로 다른 하위 집합이 포함된 서로 다른 버전의 글꼴 파일을 자동으로 제공할 수 있습니다. 예를 들어 Google Fonts는 이 작업을 기본적으로 실행합니다.
/* devanagari */
@font-face {
font-family: 'Poppins';
font-style: normal;
font-weight: 400;
font-display: swap;
src: url(https://fonts.gstatic.com/s/poppins/v20/pxiEyp8kv8JHgFVrJJbecnFHGPezSQ.woff2) format('woff2');
unicode-range: U+0900-097F, U+1CD0-1CF6, U+1CF8-1CF9, U+200C-200D, U+20A8, U+20B9, U+25CC, U+A830-A839, U+A8E0-A8FB;
}
/* latin-ext */
@font-face {
font-family: 'Poppins';
font-style: normal;
font-weight: 400;
font-display: swap;
src: url(https://fonts.gstatic.com/s/poppins/v20/pxiEyp8kv8JHgFVrJJnecnFHGPezSQ.woff2) format('woff2');
unicode-range: U+0100-024F, U+0259, U+1E00-1EFF, U+2020, U+20A0-20AB, U+20AD-20CF, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
/* latin */
@font-face {
font-family: 'Poppins';
font-style: normal;
font-weight: 400;
font-display: swap;
src: url(https://fonts.gstatic.com/s/poppins/v20/pxiEyp8kv8JHgFVrJJfecnFHGPc.woff2) format('woff2');
unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+2000-206F, U+2074, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
자체 호스팅으로 전환하는 경우 이는 쉽게 놓칠 수 있고 로컬에서 글꼴 파일이 더 커질 수 있는 최적화 방법입니다.
글꼴 제공업체에서 허용하는 경우 API(Google Fonts는 text
매개변수를 제공하여 이를 지원)를 통해 또는 글꼴 파일을 수동으로 수정한 후 자체 호스팅하여 글꼴을 수동으로 하위 집합으로 지정할 수도 있습니다. 글꼴 하위 집합을 생성하는 도구로는 하위 글꼴과 글리프저가 있습니다. 하지만 하위 설정 허용 및 자체 호스팅을 사용하는 글꼴의 라이선스를 확인하시기 바랍니다.
웹 글꼴 사용 줄이기
가장 빠른 글꼴 제공은 애초에 요청되지 않은 글꼴입니다. 시스템 글꼴과 가변 글꼴은 사이트에서 사용되는 웹 글꼴의 수를 줄이는 두 가지 방법입니다.
시스템 글꼴은 사용자 기기의 사용자 인터페이스에서 사용하는 기본 글꼴입니다. 시스템 글꼴은 일반적으로 운영체제 및 버전에 따라 다릅니다. 글꼴이 이미 설치되어 있으므로 글꼴을 다운로드할 필요가 없습니다. 시스템 글꼴은 특히 본문 텍스트에 적합합니다.
CSS에서 시스템 글꼴을 사용하려면 system-ui
를 font-family로 나열합니다.
font-family: system-ui
가변 글꼴의 기본 개념은 단일 가변 글꼴을 여러 글꼴 파일의 대체로 사용할 수 있다는 것입니다. 가변 글꼴은 '기본' 글꼴 스타일을 정의하고 글꼴을 조작하기 위한 '축'을 제공하는 방식으로 작동합니다. 예를 들어 Weight
축이 있는 가변 글꼴을 사용하면 이전에는 밝은, 일반, 굵게, 매우 굵게에 별도의 글꼴이 필요했던 레터링을 구현할 수 있습니다.
가변 글꼴로 전환하면 모든 사이트에 이점이 있는 것은 아닙니다. 변형 글꼴에는 여러 스타일이 포함되어 있으므로 일반적으로 하나의 스타일만 포함하는 개별 비변형 글꼴보다 파일 크기가 큽니다. 가변 글꼴을 사용하면 가장 큰 개선 효과를 얻을 수 있는 사이트는 다양한 글꼴 스타일과 두께를 사용하고(사용해야 하는) 사이트입니다.
글꼴 렌더링
아직 로드되지 않은 웹 글꼴이 있으면 브라우저는 딜레마에 직면하게 됩니다. 웹 글꼴이 도착할 때까지 텍스트 렌더링을 보류해야 할까요? 아니면 웹 글꼴이 도착할 때까지 대체 글꼴로 텍스트를 렌더링해야 하나요?
브라우저마다 이 시나리오를 다르게 처리합니다. 기본적으로 Chromium 기반 브라우저와 Firefox 브라우저는 연결된 웹 글꼴이 로드되지 않은 경우 최대 3초 동안 텍스트 렌더링을 차단합니다. Safari는 텍스트 렌더링을 무기한 차단합니다.
이 동작은 font-display
속성을 사용하여 구성할 수 있습니다. 이 선택사항은 상당한 영향을 미칠 수 있습니다. font-display
는 LCP, FCP, 레이아웃 안정성에 영향을 줄 수 있습니다.
적절한 font-display
전략 선택
font-display
는 연결된 웹 글꼴이 로드되지 않은 경우 브라우저에 텍스트 렌더링을 진행하는 방법을 알려줍니다. font-face별로 정의됩니다.
@font-face {
font-family: Roboto, Sans-Serif
src: url(/fonts/roboto.woff) format('woff'),
font-display: swap;
}
font-display
에 사용할 수 있는 값은 5가지입니다.
값 | 차단 기간 | 교체 기간 |
---|---|---|
자동 | 브라우저에 따라 다름 | 브라우저에 따라 다름 |
차단 | 2~3초 | 무한 |
전환 | 0밀리초 | 무한 |
대체 | 100ms | 3초 |
선택사항 | 100ms | 없음 |
- 차단 기간: 차단 기간은 브라우저에서 웹 글꼴을 요청할 때 시작됩니다. 차단 기간 동안 웹 글꼴을 사용할 수 없는 경우 글꼴이 보이지 않는 대체 글꼴로 렌더링되므로 사용자에게 텍스트가 표시되지 않습니다. 차단 기간이 끝날 때 글꼴을 사용할 수 없는 경우 대체 글꼴로 렌더링됩니다.
- 스왑 기간: 스왑 기간은 차단 기간 후에 발생합니다. 스왑 기간 중에 웹 글꼴을 사용할 수 있게 되면 '전환'됩니다.
font-display
전략은 성능과 미학 간의 절충에 관한 다양한 관점을 반영합니다. 따라서 개별 환경설정, 웹 글꼴이 페이지 및 브랜드에 얼마나 중요한지, 지연된 글꼴을 교체할 때 얼마나 불편할 수 있는지에 따라 권장되는 접근 방식을 제공하기는 어렵습니다.
대부분의 사이트에 가장 적합한 세 가지 전략은 다음과 같습니다.
성능이 최우선순위인 경우:
font-display: optional
를 사용합니다. 이는 가장 '성능이 좋은' 접근 방식입니다. 텍스트 렌더링이 100ms 이상 지연되지 않으며, 글꼴 바꾸기와 관련된 레이아웃 변경이 발생하지 않습니다. 단점은 웹 글꼴이 늦게 도착하면 사용되지 않는다는 점입니다.텍스트를 빠르게 표시하는 것이 가장 중요하지만 여전히 웹 글꼴이 사용되도록 하려는 경우:
font-display: swap
을 사용하되 레이아웃이 바뀌지 않도록 글꼴을 충분히 일찍 제공해야 합니다. 이 옵션의 단점은 글꼴이 늦게 도착할 때 불편하게 바뀌는 점입니다.텍스트가 웹 글꼴로 표시되도록 하는 것이 가장 중요한 경우:
font-display: block
를 사용하되 텍스트의 지연을 최소화할 수 있도록 글꼴을 충분히 일찍 제공해야 합니다. 단점은 초기 텍스트 표시가 지연된다는 점입니다. 이러한 지연에도 불구하고 텍스트가 실제로는 보이지 않게 그려지므로 레이아웃이 여전히 이동할 수 있으며, 따라서 공간을 예약하는 데 대체 글꼴 공간이 사용됩니다. 웹 글꼴이 로드되면 차이 공간이 필요하고 그에 따라 위치가 달라질 수 있습니다. 그러나 텍스트 자체가 이동하는 것으로 보이지 않으므로font-display: swap
보다 덜 거슬리는 변화일 수 있습니다.
또한 이 두 가지 접근 방식을 결합할 수 있다는 점에 유의하세요. 예를 들어 브랜딩 및 기타 시각적으로 고유한 페이지 요소에는 font-display: swap
를 사용하고 본문 텍스트에 사용되는 글꼴에는 font-display: optional
를 사용합니다.
대체 글꼴과 웹 글꼴 간의 시프트를 줄입니다.
CLS 영향을 줄이려면 새 size-adjust
속성을 사용하면 됩니다. 자세한 내용은 CSS size-adjust
에 관한 도움말을 참고하세요. 이는 Google 도구 모음에 새로 추가된 것이므로 현재 더 고급스럽고 약간 수동적입니다. 하지만 앞으로 도구가 개선될 예정이니 실험해 보고 지켜보세요.
결론
웹 글꼴은 여전히 성능 병목 현상이지만, 이 병목 현상을 최대한 줄이기 위해 글꼴을 최적화할 수 있는 옵션이 점점 늘어나고 있습니다.