FOIT, FOUT és a font-display property

Szerző:   |   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
  • Az Axure használata

    A munkáltató biztosítja számodra a munkavégzéshez szükséges hardvereket és szoftvereket. Ha nem így van, akkor annál a cégnél nem szabad dolgozni....

  • Az Axure használata

    Köszi a választ! Annyit szeretnék még kérdezni, hogy ha olyan a munkahely hogy adobe szoftverekkel kell dolgozni mondjuk a saját gépemröl, akkor nekem...

  • Az Axure használata

    Próbafeladatot szoktak adni amit meg kell oldanod. Jobb esetben otthon, de nem egy olyan interjún voltam már, ahol leültettek egy géphez aztán ott hel...

  • Az Axure használata

    Hali. Azt szeretném kérdezni, hogy te mit tanácsolsz egy pályakezdö webdesignernek, ha el akar helyezkedni? Még nem dolgoztam korábban sosem webdesign...

  • A Bootstrap 4 grid használata

    Azt használsz ami tetszik. A CSS reset cuccok többsége lassan 10 éves, ma már nem nagyon van rájuk szükség. Bootstrap akkor kell, ha az adott projekth...

  • A Bootstrap 4 grid használata

    Szia! Nem rég kezdtem tanulni, kis segítséggel õssze tudok rakni egy oldalt Html+css a többivel még most ismerkednek. Nem nagyon vagyok vele tisztába ...

  • A villanyszerelés örömei panelben

    Nem, én B-t raktam mindenhova és most már ötödik éve nincs vele gondom....

  • A villanyszerelés örömei panelben

    Szia Jövő héten kezdek bele, egy ugyan ilyen projectbe. Még mindig tartod azt az állítást, hogy jó a C karakterisztikájú kismegszakító? És mé...

  • ActionScript 3 eseménykezelés

    Sima CSS animációt....

  • ActionScript 3 eseménykezelés

    Helló! Kiváló a "Banner mutációk" -ról szóló videód. A legnagyobb erénye számomra, hogy a hatékony munkavégzést is bemutattad. Amiért a flash témakor...

  • Egyszerű tükröződés készítése Photoshopban

    Koszi:)...

  • Bootstrap carousel

    Nem találkoztam még ilyennel, ezt a két linket találtam hozzá: https://stackoverflow.com/questions/16244306/single-picture-displaying-upside-down-in-b...