FOIT, FOUT és a font-display property

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
  • A villanyszerelés örömei panelben

    Gratulálok! Szép leírás! Azt szeretném kérdezni, hogy nálam 3×32 amper lessz, bővítés után. Laikusként kérdem, így három Fi-relé kell? És mekkorát, é...

  • A villanyszerelés örömei panelben

    @Utolsó hozzászóló: Szia, olyan nincs, hogy 3 fázis érkezik be 3 külön vezetéken. Vagy 1 fázis 1, vagy 3 fázis 3 vezetéken. (+ a nulla) Ha az óráná...

  • A Pico CMS

    pico-release-v2.1.0, nincs benne content-samle, a content üres, nincs benne php nincs sub mappa és fájl sem, mégis ott van a subindex a menunuben...

  • CSS transition

    Köszönöm a válaszod! Igen ezzel már, próbálkoztam, de amint sikrül térben elhelyezni a megfelelő helyre a köröket, megszűnik működni rajtuk az effek...

  • CSS transition

    z-index-et állíts be a menüre, és arra is ami most fölé kerül. Értelemszerűen a menün legyen a magasabb érték....

  • CSS transition

    Kedves Tamás! Remélem még aktív a blog és tudsz nekem segíteni. Nagyon tetszett a videód, ki is próbáltam. A videód alapján beépitettem ezeket az ...

  • A villanyszerelés örömei panelben

    Egy fázis jön be három vezetéken keresztül. Az óránál egy darab megszakító van csak. Ezért kérdeztem, hogy milyen fi relét javasoltok?...

  • A villanyszerelés örömei panelben

    Ez nem igaz, mert az óránál ott a 3 biztosító darabja 20 A...

  • A shape-outside CSS property

    Olyasmit találtam hogy a szöveg részt 2 részre osztjuk bal és jobb......

  • 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....