A simple CSS @keyframes
animation demo with four stages.
View the GitHub page for this example.
Note that animation makes processor demands, which are of special concern on mobile devices:
This is not a good exampe, as it animates the background colour of the body infinitely. Here's why…
- the CSS
transform
property uses a RenderLayer so the GPU can do the calculations - works for CSS
transform
property values:translate
,scale
,rotate
,opacity
- other properties need a more extensive screen redraw and 'trigger layout'
- browser 'layout' forces the CPU to recalculate every frame
- never animate other properties for mobiles or with
animation-iteration: infinite;
So only use animation for simple once-only or brief user interaction cues (e.g. on hover) or to attract attention with a repeating animation triggered by some user action e.g. adding a class with style rules to:
- 'pulse' a missing form field, using
opacity
in an animation - 'jiggle' a button to suggest clicking, using
rotate
in an animation
- TL:DR; Read this one if you don't read the others: High Performance Animations (Paul Lewis and Paul Irish, HTML5 Rocks, 2013)
- Chris Coyier's original inquiry: A Tale of Animation Performance (Chris Coyier, 2012)
- Response from Paul Irish (Google Chrome team): Why Moving Elements With Translate() Is Better Than Pos:abs Top/left (Paul Irish, 2012)