liquiddesign

Zasada 07

Ruch z szacunkiem

Animacja właściwości layoutowych przelicza geometrię strony w każdej klatce i ciągnie za sobą sąsiadów elementu. Transform i opacity działają na kompozytorze, płynnie i bez dotykania układu. Do tego część użytkowników fizycznie choruje od ruchu, więc reduced motion wyłącza ozdoby.

Przesuń kafelek A i patrz na B oraz C

Margin przelicza layout w każdej klatce i wiezie sąsiadów ze sobą. Transform zostawia układ w spokoju, a kolizję z B projektujesz świadomie.

✕ Animacja margin-left

A
B
C

B i C jadą razem z A, bo każda klatka animacji zmienia layout całego rzędu.

✓ Animacja transform

A
B
C

B i C stoją nieruchomo. Transform działa na kompozytorze i nie dotyka geometrii strony.

Reguły

  • Animacje dotyczą wyłącznie transform i opacity, layout stoi w miejscu.
  • Element animowany nie zmienia pozycji innych elementów w żadnej klatce.
  • prefers-reduced-motion redukuje przejścia do natychmiastowej zmiany stanu.
  • Ruch ma zadanie: prowadzi wzrok albo tłumaczy zmianę, nigdy nie jest tapetą.

Wzorzec w kodzie

Transform i opacity, jedyne właściwości warte animowania
.tile {
  transition: transform 0.3s ease, opacity 0.3s ease;
}

.tile.shifted {
  transform: translateX(8rem);
}
Globalny wyłącznik dla preferencji ograniczonego ruchu
@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after {
    animation-duration: 0.01ms !important;
    transition-duration: 0.01ms !important;
  }
}