2024-06-27
Zum Design eigener Dokumente (ob Web oder auf Papier) gehört die Gestaltung mit selbst gewählten Fonts. Diese können in HTML recht problemlos festgelegt werden. Da man beim Betrachter nicht voraussetzen kann, dass der eigene Wunschfont installiert ist, verwendet man Web-Fonts, die über das Internet geladen werden.
Seit Jahren stellt Google freie Fonts erfolgreich und zentral zur Verfügung.
Zu jeder Fontfamilie (das, was wir mit einem Namen kennzeichnen, z.B. "Open Sans" oder "Arial") gehören verschiedene Font-Dateien, um jede gewünschte Darstellungsart erreichen zu können. Diese werden erst einmal für normal/italic und andererseits für verschiedene Dicken der Zeichen ("weight") benötigt. Google unterteilt die Dateien außerdem nach Zielgruppen, d.h. welche Zeichen enthalten sein sollen, in "latin", "latin-ext", "greek" und einige weitere. Diese Dateien gibt es außerdem jeweils in verschiedenen Formaten für ältere und neuere Browser. Will man also Open Sans in dünn, normal, fett und ultrafett sowie dasselbe in italic, mit drei Datei-Varianten (ttf, woff, woff2), so handelt es sich bereits um 24 Dateien, ohne dass man sich um den Zeichenumfang gekümmert hat. Kein Wunder, dass die Meisten die Arbeit Google überlassen. Der Aufwand lässt sich heutzutage aber deutlich reduzieren!
Mit einer Kombination aus modernem Betriebssystem und leidlich aktuellem Browser kann man variable Fonts nutzen! Ignoriert man alte Systeme, so verringert sich der Aufwand deutlich.
Dies ist legitim:
Der Clou: Das woff2-Format ermöglicht “variable
Fonts”123.
Dies bedeutet, dass man i.d.R. keine gtrennten Dateien für schmal,
normal und fette Schrift braucht, sondern dies aus einer Datei korrekt
errechnet wird (in CSS festgelegt).
Welche Fonts es bereits gibt, kann Google Fonts gefiltert
auflisten. Sofern einem diese Fonts genügen, gelten die folgenden
Ausführungen:
Damit sind mehrere Probleme gelöst:
Bonus 1: HTTP/2 ermöglicht, dass die Fonts auf demselben Server über dieselbe Session - auch interleaved - übertragen werden. Solange dein Server nicht an sich lahm ist, sollte damit der Abruf sehr schnell sein! Prüfe, ob dein Anbieter imzwischen HTTP/2 (nur via HTTPS möglich) nutzt!
Bonus 2: Mit einem Preload kann man eine (Font-)-Datei sehr früh im Seitenaufbau übertragen lassen. Diese ist im Fall von variablen Fonts bereits sehr weit nutzbar.
Was benötigen wir?
In Stichpunkten um "regular" und "italic" zu erhalten:
<FilesMatch "\.(woff2)$">
<IfModule mod_headers.c>
set Access-Control-Allow-Origin "*"
Header</IfModule>
</FilesMatch>
@font-face {
font-family: 'EB Garamond';
font-style: normal;
font-weight: 400 800;
font-display: swap;
src: url(https://example.de/fonts/EB_Garamond.woff2) format("woff2 supports variations"),
url(https://example.de/fonts/EB_Garamond.woff2) format("woff2-variations");
}@font-face {
font-family: 'EB Garamond';
font-style: italic;
font-weight: 400 800;
font-display: swap;
src: url(https://example.de/fonts/EB_Garamond_Italic.woff2) format("woff2 supports variations"),
url(https://example.de/fonts/EB_Garamond_Italic.woff2) format("woff2-variations");
}font-family: sans-serif; }
body { , h2, h3 { font-family: "EB Garamond";}
h1font-weight: 800;}
h1 {font-style: italic;} h2 {
<H1>Garamond in GROSS</H1>
<p>Und etwas Text</p>
<H2>Garamond in kursiv</H2>
<p>Etwas Text</p>
<H3>Garamond in mittel</H3>
<p>Etwas Text</p>
<H4>Kein Garamond</H4>
<p>Der letzte Text</p>
Für “Bonus 2”:
<link
rel="preload"
as="font"
crossorigin="anonymous"
href="https://example.de/fonts/OpenSans.woff2"
type="font/woff2"
>