FOIT, FOUT és a font-display property

Szerző: Mérei Tamás   |   2019-02-15

Webfontok használata esetén gyakori jelenség a FOUT (Flash of Unstyled Text) és FOIT (Flash of Invisible Text). Nem komoly problémáról van szó, szerintem a webfejlesztők 99%-a egyáltalán nem foglalkozik vele. Ha valaki azonban abszolút 100%-os performance-ra törekszik, érdemes egy kicsit elmerülni a témában.

FOUT-ról akkor beszélünk amikor a böngésző még nem töltötte le a webfontot, de ennek ellenére megjeleníti a szöveget. Ilyenkor egy fallback betűtípus töltődik be, amit mi határozhatunk meg a font stack-ben. Ha nincs ilyen, akkor a default rendszer betűtípus kerül betöltésre. Abban a pillanatban ahogy a webfont letöltődik, a szöveg betűtípusa hirtelen megváltozik, amit egy villanásnak észlelünk, innen a jelenség neve.

A FOUT elkerülése érdekében a böngészők eltérő módszereket alkalmaznak. Általános megoldás, hogy 3 másodpercet várnak a webfont betöltésére és addig semmilyen szöveget nem jelenítenek meg. Ha ennyi idő alatt sem töltődik le a webfont, akkor a szöveg a fallback betűtípussal jelenik meg. Ezzel ugyan elkerülhető a FOUT, viszont, a semmiből hirtelen előtűnő szöveg miatt FOIT jelenségről beszélünk.

A böngészők alapértelmezett font renderelési metódusát korábban csak JavaScript segítségével tudtuk módosítani. Ennek kiváltására vezették be a font-display CSS property-t, melyhez hat különböző érték tartozik:

  • auto Ez az alapértelmezett, a böngészőre bízzuk a dolgot.
  • swap A szöveg azonnal renderelésre kerül a fallback betűtípussal amíg a webfont le nem töltődik. Akkor célszerű használni, ha a dizájn kevésbé fontos és szövegnek azonnal látszódnia kell az oldalon. Hátránya, hogy FOUT jelenség előfordulhat.
  • block A szöveg egész addig láthatatlan marad, amíg a webfont le nem töltődik. Akkor érdemes használni, ha a szöveges tartalom valamilyen oknál fogva kizárólag a webfonttal olvasható. FOIT jelenség előfordulhat, és akár az is, hogy egyáltalán nem jelenik meg szöveg az oldalon, ha a webfont valamiért nem töltődik be.
  • fallback A block és a swap közötti arany középút. A FOIT elkerülése érdekében csak nagyon kevés ideig nem jeleníti meg a szöveget (100 ms). Ha ennyi idő alatt nem töltődik le a webfont, akkor utána már nem változtatja meg az oldal betűtípusát. Ezzel a módszerrel elkerülhető a FOIT és FOUT is, viszont előfordulhat, hogy az oldalunk a fallback betűtípussal töltődik be és úgy is marad. Ha ezt meglátja az oldalt tervező grafikus, valószínűleg égnek áll a haja 🙂
  • optional Hasonló a fallback-hez, azzal a különbséggel, hogy itt a böngészőre van bízva a dolog. Ha a nagyon rövid (100 ms) block period alatt nem töltődött le a webfont, a böngésző dönti el a továbbiakat. Ha a letöltési probléma a user alacsony sávszélességének köszönhető, felesleges tovább erőltetni a webfont letöltését a háttérben, ergo marad a fallback font.

A font-display jelenleg Firefox, Chrome, Safari és Opera alatt működik.

A leírtak alapján azt hiszem kijelenthető, hogy ha a webfont betöltési ideje 100 ms alatt van, akkor nem kell ezzel a problémával foglalkozni. Ezért (is) fontos, hogy csak azokat a fontokat töltsük be, amiket valóban használunk az oldalon.

Hozzászólás

Keresés a blogon
Kategóriák
Legújabb hozzászólások
  • Responsive menü

    Itt a működő kód, innen másold ki: https://cyrex.hu/uploads/2014/08/responsive-menu/...

  • Responsive menü

    Szia. A kódok alapján, meg persze a videót végignézve megcsináltam a menüt. Sajnos nem úgy működik, ahogy kellene. A menü3 almenüi nem gördülnek le, ...

  • A shape-outside CSS property

    Szerintem azt sehogy....

  • A villanyszerelés örömei panelben

    Panelban ugyan az a három fázis jön be három MCU-n és nem 3fázis... Keresztmetszet növelés miatt csinálták anno......

  • A shape-outside CSS property

    Szia Jó lett a videó. De mi van akkor ha a képet a szöveg közepére szeretném tenni, és azt akarom hogy így fusson körbe a szöveg....

  • Bootstrap űrlapok

    Jó lett :) Már kezdtem aggódni hogy eltűntél vagy valami hogy ilyen sokáig nem volt videó. 2 naponta néztem az oldaladat hogy hátha.... :)...

  • A villanyszerelés örömei panelben

    Ha három fázisod van, akkor három fázisú Fi relét kell venni....

  • A villanyszerelés örömei panelben

    Szia, ha panellakásba három vezetéken jön be az egy fázis, akkor három fi relét kellene berakni?...

  • A villanyszerelés örömei panelben

    "3 vezeték jön be, fázis-nulla-föld, tehát már az óránál szétválasztották a PEN vezetéket PE-re és N-re vagy más módon, de külön vezetéken jön az N és...

  • Dia szkennelés házilag

    Ezt a fajtát nem tudom, hogy lehet még kapni. Normál diavetítőt lehet kapni nagyobb játékboltokban például....

  • Bootstrap carousel

    Ennél a réginél nem tudom, hogy volt e már ilyen opció, de az újnál már van olyan, hogy touch="true"...

  • Adobe XD VS. Lunacy

    Sketch-et nem használok, mert nincs mac-em. Axure-t használok, arról találsz anyagot az oldalon....