κ°μ
* μμΈνμ -첫 νλ©΄(λμ보λ) μ§μ μ λλ¦Ό
πμμμ μ΄λ λ€. 'μ°λ¦¬ μ¬μ΄νΈκ° λ무 λλ €μ.. μ΄λ»κ² κ°μ μλ κΉμ?' λΌλ λ§μ λ£κ³ μ¬μ΄νΈλ₯Ό λ€μ΄κ°λ΄€λ€.
μΈμμ.. μ¬μ©μ κ²½νμ΄ λ―Έμ² μμ΄κΈ°λ μ μ λμ‘°μ°¨λ μ΄ννκ³ μΆμ μλμλ€.
DevTools λ‘ λ€νΈμν¬ μ‘°νν΄λ³΄λ μ¬μ΄νΈ μ§μ μ, Fontμ λν CSS νμΌμ λΆλ¬μ€λλ° κ½€λ ν° λͺ«μ νκ³ μμλ€.
μμΈ
μμΈμ Font! ꡬκΈμμ fonts λ₯Ό λΆλ¬μ€λ κ³³μμ ν° Delay κ° μμλλ°, λΆνμν 리μμ€ μμ²κ³Ό ν¨κ» μμ² λ§μ font λ₯Ό λΆλ¬μ€κ³ μμλ€.
μλ²μ κ²½λνλ₯Ό μν΄μμΈμ§(μΆμΈ‘) Google fonts λ₯Ό μ§μ νΈμΆνκ³ μμλλ° μ¬μ§μ΄ μ¬μ©νμ§ μλ font λ€λ μ μΈνμ¬ νΈμΆμ€μ΄μλ€.. (μ΄λ°.. cdn μλ²κ° κ°κΉμ΄μ§λ λͺ¨λ₯΄λλ°..?)
λ€νν CSS Font μ λν μλ μ΄μλ κ³Όκ±°μλ κ²½νν μ μ΄ μμλλ°, μλ λ΄μ©μ ν΅ν΄ ν΄κ²°νλ€.
μ΄λ²μλ κΌ κΈ°λ‘ν΄μΌμ§..
- 리μμ€μ Local ν
- λͺ¨λ νμΌ ν¬λ§· μ¬μ©
- font-display μ¬μ©
- FOIT/FOUT μ¬μ©
- CSSμ preload
μ‘°μΉ
리μμ€μ Local ν
λΆνμν 리μμ€μ μΈλΆ νΈμΆμ λ§κΈ°μν΄(λ€νΈμν¬ μ΄μλ‘ μΈν μ§μ°μ μμ κΈ° μν΄) font νμΌμ λ€μ΄λ‘λ λ°μ νλ‘μ νΈμ resources/fonts/ λλ ν 리λ₯Ό λ§λ€μ΄ μΆκ°νμλ€.
λͺ¨λ νμΌ ν¬λ§· μ¬μ©
μΉν°νΈ νμ₯μ μ’ λ₯
- EOT: IE8 μ΄νμΌ κ²½μ° μ¬μ©
- TTF: ꡬν μλλ‘μ΄λ λ²μ (4.4)λ₯Ό μ§μνλ κ²½μ°μ μ¬μ©
- WOFF: λλΆλΆμ λͺ¨λ λΈλΌμ°μ μμ μ§μ
- WOFF2: WOFFλ³΄λ€ μμΆλ₯ μ΄ 30% μ λ λ μ’λ€.
font-display (FOIT/FOUT)μ¬μ©
FOIT(Flash of Invisible Text)
λΈλΌμ°μ κ° ν°νΈλ₯Ό λ€μ΄λ‘λ νκΈ° μ μ ν°νΈκ° 보μ΄μ§ μλλ‘ μ€μ
FOUT(Flash of Unstyled Text)
λΈλΌμ°μ κ° ν°νΈλ₯Ό λ€μ΄λ‘λ νκΈ° μ μ ν°νΈκ° μ μ©λμ§ μμ κΈμκ° λ³΄μ΄λλ‘ μ€μ
ν΄κ²°
1. μΌλ¨ λΆνμν 리μμ€ νΈμΆ μ κ±° - @font-face μ cdn μΈλΆνΈμΆμ local ν
2. νμ₯μλ₯Ό νλλ‘ μ€μ¬ Fail μΌμ΄μ€λ₯Ό κ°μ - IE11 μ§μμ λ°°μ νλ κ²μΌλ‘ 'woff2' λ§μ μ¬μ©νκΈ°λ‘ Rule μ€μ
3. FOUT μΌλ‘ 무쑰건 κΈμκ° λ³΄μ΄κ² μ€μ (λ‘λ©μ΄λΌλ 보μ΄μ§ μλ κ²μ λ§μ΄ μλλ€κ³ μκ°λμ΄ μ€μ )
4. cssμ min μ²λ¦¬ - νΌμ³μ§ CSSλ₯Ό 1rowλ‘ μ€μ¬, νΌν¬λ¨Όμ€ ν₯μμ μ§ννλ€.
5. Local CSS function μ¬μ© - src μ local function μ λͺ μνλ©΄, 리μμ€λ₯Ό λ°λ‘ μμ²νμ§ μλλ€.
/* fonts.gstatic.com/~~ κ²½λ‘λ₯Ό λ‘μ»¬λ‘ μμ */
@font-face {
font-family: 'Noto Sans KR';
font-style: normal;
font-weight: 100;
src: local('Noto Sans KR'), url(/font/NotoSansKR-Thin.woff2) format('woff2'),
url(/font/NotoSansKR-Thin.otf) format('opentype');
font-display: swap;
}
@font-face {
font-family: 'Noto Sans KR';
font-style: normal;
font-weight: 300;
src: local('Noto Sans KR'),url(/font/NotoSansKR-Light.woff2) format('woff2'),
url(/font/NotoSansKR-Light.otf) format('opentype');
font-display: swap;
}
@font-face {
font-family: 'Noto Sans KR';
font-style: normal;
font-weight: 400;
src: local('Noto Sans KR'),url(/font/NotoSansKR-Regular.woff2) format('woff2'),
url(/font/NotoSansKR-Regular.otf) format('opentype');
font-display: swap;
}
@font-face {
font-family: 'Noto Sans KR';
font-style: normal;
font-weight: 500;
src: local('Noto Sans KR'),url(/font/NotoSansKR-Medium.woff2);
font-display: swap;
}
@font-face {
font-family: 'Noto Sans KR';
font-style: normal;
font-weight: 700;
src: local('Noto Sans KR'),url(/font/NotoSansKR-Bold.woff2) format('woff2'),
url(/font/NotoSansKR-Bold.otf) format('opentype');
font-display: swap;
}
@font-face {
font-family: 'Noto Sans KR';
font-style: normal;
font-weight: 900;
src: local('Noto Sans KR'),url(/font/NotoSansKR-Black.woff2) format('woff2'),
url(/font/NotoSansKR-Black.otf) format('opentype');
font-display: swap;
}