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
.tile {
transition: transform 0.3s ease, opacity 0.3s ease;
}
.tile.shifted {
transform: translateX(8rem);
}@media (prefers-reduced-motion: reduce) {
*, *::before, *::after {
animation-duration: 0.01ms !important;
transition-duration: 0.01ms !important;
}
}