Moderní tvorba webových aplikací

O webu

Nastavení výšky responsivního obrázku

Jak zabránit poskakování responsivních obrázků během načítání stránky.

8 minut

Nejsnazší řešení responsivních obrázků je nastavení maximální šířky <img> na 100 % a nastavení výšky na auto, aby se dopočítala podle šířky.

img {
  max-width: 100%; 
  height: auto;
}

Obrázky se potom sice hezky přizpůsobují velikosti okna, ale trpí zásadním nedostatkem – prohlížeč nezná výšku, dokud obrázek nestáhne. To způsobuje nepěkné poskakování stránky během načítání, které navíc zdržuje vykreslování.

Prohlížeč zkrátka neví, kolik místa má pro obrázek vyhradit.

Odsunutí textu během načítání

Naštěstí existuje následující řešení:

Využívá se toho, že padding se počítá z šířky elementu a v případě výchozího „obsahového“ box modelu (box-sizing: border-box) se do rozměrů sčítá padding s výškou. Pokud tedy bude height nulová, bude celkovou výšku určovat hodnota paddingu.

Řešení

Pro nastavení výšky obrázku v závislosti na proměnlivé šířce je tak nutné nastavit poměr stran jako padding.

Dopočítat potřebný poměr jde snadno vydělením výšky obrázku jeho šířkou a převedením na procenta (vynásobit stem). Níže v článku je přímo generátor kódu, který po zadání URL obrázku připraví potřebné CSS.

Realisace v CSS

V CSS je postup takový, že se pro obrázek vytvoří kontejner (obal), který vymezí prostor na šířku a na výšku, což zabrání poskakování, a do tohoto obalu se vloží samotná značka <img>.

HTML kód:

<div class="img-cover">
  <img src="">
</div>

Element .img-cover bude mít nastaven požadovaný poměr stran (v tomto případě 75 %):

.img-cover {
    height: 0;
    padding-bottom: 75%;
}

Obrázek se potom pouze roztáhne podle tohoto obalu:

.img-cover img {
  width: 100%;
}

V případě, že bude dostupná šířka pro .img-cover větší než skutečná šířka obrázku, bude obrázek roztažen nad své rozměry.

Je-li to nežádoucí, je potřeba všechno obalit do dalšího <div>u:

<div class="img">
  <div class="img-cover">
    <img src="">
  </div>
</div>

Tento obal .img bude mít nastavenou maximální šířku (max-widht). Odsazení (padding) elementu .img-cover, které ve finále stanovuje výšku, se totiž počítá z šířky svého rodiče.

Generátor CSS kódu pro přepočet rozměrů v px na procenta:

.img-cover {height: 0; padding-bottom: 75%}
.img-cover img {width: 100%; height: auto}

Obrázky s různými rozměry

Problém nastane, když je na stránce hromada obrázků s různými rozměry. Potom by ruční počítání poměru výšky a šířky každého z nich bylo značně pracné.

Řešení na straně serveru

V případě, že na straně serveru existuje nějaký mechanismus, který obrázkům dokáže nastavovat rozměry, může rovnou dopočítat i poměr s maximální šířkou a přidat tato pravidla do style atributu.

<div class="img" style="max-width: 200px">
  <div class="img-cover" style="padding-bottom: 75%">
    <img width="200" height="150">
  </div>
</div>

Výše uvedený kód počítá s CSS pravidly:

.img-cover {height: 0}
.img-cover img {width: 100%; height: auto}

V budoucnu je možné, že by rozměr z atributů mohl jít získat přes attr a dopočítat funkcí calc. Momentálně ale attr funguje pouze u vlastnosti content.

Řešení v JavaScriptu

Použít k nastavení rozměrů JS je spíš nouzové řešení, protože některé obrázky se mohou začít načítat dříve, než se stihne spustit skript nastavující rozměry.

Dále řešení v JavaScriptu přichází pouze v úvahu, když obrázky už mají nastaveny rozměry v HTML atributech width a height. JS sice umí zjistit skutečné rozměry obrázku, potřebuje ho ale k tomu nejprve načíst, což je v tomto případě problém.

JS tedy projde obrázky na stránce (document.images) a obalí je do elementů zabírající prostor o rozměrech obrázku.

Aby bylo poskakování co nejmenší, měl by se tento kód spustit na stránce co nejdříve.

  • Živá ukázka – vytvoření placeholderů pro responsivní obrázky

Netrpí poskakováním můj web?

Nejlepší způsob, jak zjistit, jestli tímto problémem web netrpí, je vypnutí/zakázání obrázků.

V Chrome je toto nastavení pod chrome://settings/content.

Všimnout si poskakování stránky jde i při nastavení velmi pomalého připojení ve vývojářských nástrojích.

Bez vypínání obrázků v prohlížeči si jde pomoci krátkým JavaScriptem, který všechny obrázky na stránce nahradí 1px bílým GIFem.

Po spuštění tohoto kódu by dobře udělaná stránka neměla nijak poskočit.

(function(img) {
    for (var i = img.length; i--; ) {
        img[i].src = "";
    }
})(document.images);

Spustit tento kód přímo na stránce jde třeba vložením po napsání javascript: do adresního řádku (kopírovat „javascript:“ z bezpečnostních důvodů jít nemusí).

Odkazy jinam

Související články

V jakém programu upravovat obrázky

Jaký program zvolit pro rychlou úpravu obrázků.

2 minuty

Object-fit

CSS vlastnost object-fit umí přizpůsobit obrázek pevné velikosti.

4 minuty

Lazy loading obrázků

Načtení obrázků, až když je na ně odrolováno. Různé postupy řešení.

6 minut

SVG

SVG je grafický formát vhodný pro grafické prvky, které mají mít možnost měnit svou velikost.

28 minut

Web jecas.cz píše Bohumil Jahoda, kontakt
Seznam všech článků
2013–2025