Retour au glossaire
Sites & dev

Cumulative Layout ShiftCLS

Metryka Core Web Vitals mierząca wizualną stabilność strony podczas ładowania — niechciane przeskoki układu. Cel: ≤ 0,1.

CLS (Cumulative Layout Shift) określa, na ile układ strony „skacze” podczas jej ładowania. Znacie to doświadczenie: macie zamiar kliknąć w przycisk, na górze doładowuje się baner reklamowy, wszystko zjeżdża w dół, klikacie w coś innego. To właśnie zły CLS — a Google karze go od 2021 roku w ramach Core Web Vitals. Progi: ≤ 0,1 = dobry, 0,1–0,25 = do poprawy, > 0,25 = zły (w 75. percentylu).

Obliczenie jest proste do zrozumienia: dla każdego elementu, który porusza się między dwoma klatkami, mnożymy proporcję viewportu objętą zmianą (impact fraction) przez dystans przesunięcia (distance fraction). Sumujemy to przez cały czas życia strony. Typowi winowajcy: (1) obrazy bez podanych wymiarów (`width`/`height`), (2) fonty webowe powodujące FOUT (Flash of Unstyled Text) przy doładowaniu, (3) banery reklamowe lub cookie dorzucane dynamicznie u góry, (4) embedy (Twitter, YouTube) auto-skalujące się, (5) animacje CSS na właściwościach non-composite.

Poprawki są zwykle szybkie — załatwiamy je w kilka godzin podczas bezpłatnego audytu. Po stronie kodu: zawsze deklarować `width` i `height` na obrazach (lub używać komponentu Image z Next.js, który robi to za nas), używać `font-display: optional` lub poprawnie skonfigurowanych fallbacków, rezerwować przestrzeń dla reklam/embedów placeholderem właściwej wielkości, animować wyłącznie `transform` i `opacity`. CLS jest najłatwiejszym z trzech Core Web Vitals do naprawy — gdy świeci się na czerwono, znaczy to po prostu, że frontowi brakuje rygoru. Naprawiamy go na wszystkich naszych stronach na zamówienie.

4 główne przyczyny złego CLS

  • Obrazy bez wymiarów: zawsze `width`/`height` (lub `aspect-ratio`) — to 80% przypadków w praktyce.
  • Źle skonfigurowane fonty webowe: `font-display: optional` lub fallback z `size-adjust`, by uniknąć skoku przy swapie.
  • Reklamy/cookie dynamicznie na górze: rezerwować stały kontener lub wyświetlać na dole/sticky.
  • Animacje CSS non-composite: animować `transform`/`opacity` zamiast `top`/`left`/`width`/`height`.
Bezpłatny audyt · 48 h

Nie wiesz, gdzie tkwi problem?
Zaudytujemy Twoją stronę. Bezpłatnie.

5 osi pod lupą — SEO, GEO, wydajność, konwersja, tracking. Wyceniony raport PDF + 30 min omówienia w prezencie. Bez zobowiązań, bez karty kredytowej.

Zamów bezpłatny audyt

Raport w 48 h · 30 min omówienia w prezencie

  • SEO Google
  • GEO · ChatGPT, Perplexity
  • Wydajność i Core Web Vitals
  • Konwersja i UX
  • Tracking i analityka
Devis sous 48h

Nie chcesz dzwonić?
Opisz swój projekt
w 5 minut.

Un projet sur ce sujet ? Décrivez-le en 5 min, on vous renvoie une architecture, un chiffrage et un planning.

  • 1Opisujesz swoją potrzebę
  • 2My wyceniamy i uzasadniamy
  • 3Wycena trafia do Twojej skrzynki
Décrire mon projet

Bez zobowiązań · Odpowiedź w 48 h