Create cool UI animations with CSS
Your guide to using CSS transitions, keyframes and SVG animation to create animations that delight.
CSS keyframes are used for complex or repeatable animations. They enable us to define multiple property values to animate between. Keyframe animations can be reused and repeated, unlike CSS transitions.
CSS keyframe animations are defined using the @keyframes syntax. This works much like a media query where we nest elements inside of the @ statement. Inside the keyframe declaration we have two options: we can use the keyword to and from or we can define our timeline using percentages.
Keyword animations
When the animation we're creating only has two points to animate between, we can use the to and from syntax, in fact we can use just to, providing the original property value is set on the element we're going to be animating.
#record {
transform: rotate(0deg);
animation: rotate 1s;
}
@keyframes rotate {
to {
transform: rotate(360deg);
}
}
Percentage animations
When creating animations where we need to define more than one point to animate, we can use percentages. This enables us to have precise control over our animation.
@keyframes flash {
25% { opacity: 1; }
27% { opacity: 0.4; }
29% { opacity: 1; }
31% { opacity: 0.4; }
75% { opacity: 1; }
}
Applying an animation
Animation in CSS has a number of properties we can set in order to have precise control over the playback of our keyframe animations. Some, like animation-duration, animation-delay, animation-iteration-count, animation-play-state and animation-name are all fairly self-explanatory, while some of the other properties can be a little trickier to learn and utilise to their full potential.
animation-timing-function
Timing functions in animation are the same as transitions – we can use either keywords or set a custom timing function by using the cubic-bezier value. Take a look at a full list of timing keywords.
animation-direction
When applying our animations, we have the ability to play them back in a number of ways. The default value is normal, which will play the animation forwards. We can also play the animation in reverse or alternate the animations playing forwards and backwards.
Get the Creative Bloq Newsletter
Daily design news, reviews, how-tos and more, as picked by the editors.
animation-fill-mode
The fill mode value enables us to choose what should happen at the end of an animation to the value that we have changed. For example, setting the value to forwards will keep the property values from the end of the animation, whereas the default value none will return the elements to their original state after the animation has finished.
Animation shorthand
All of the animation properties can be combined into a shorthand statement using the 'animation' property. We are free to omit the values we do not need and want to leave as the default values.
animation: duration || timing-function ||
delay ||
iteration-count || direction || fill-mode ||
play-state || name;
animation: 500ms linear infinite flash;
Next page: Learn how to manage the performance of your animations
Thank you for reading 5 articles this month* Join now for unlimited access
Enjoy your first month for just £1 / $1 / €1
*Read 5 free articles per month without a subscription
Join now for unlimited access
Try first month for just £1 / $1 / €1
Steven is a digital creative from Stockton-on-Tees, UK. An experienced Head of UX, Steven has written a number of articles on web design and front-end development, as well as delivering a talk at CSSConf Budapest on the potential of CSS animations. He is currently Head of UX at Aero Commerce.
data:image/s3,"s3://crabby-images/dc386/dc386540a9d261b49119873ac7e8560fb0de831e" alt="A screenshot of the new YouTube UI"
data:image/s3,"s3://crabby-images/f6fde/f6fde9e0e95758287e04b2c81fcb8d304d01875e" alt="Adobe XD logo"
data:image/s3,"s3://crabby-images/e5064/e50642eadcb39737f316707cb833ecf8cec2290a" alt="UX revolution"
data:image/s3,"s3://crabby-images/a30d5/a30d5b89bab4b203290b7891602c1e8c0f222137" alt="Screenshot of busy webpage full of graphics and different fonts"
data:image/s3,"s3://crabby-images/ca146/ca1466fd84109c0c62f05aa11f6da4d5653d8326" alt="Free Figma subscription offer with a UX design course"
data:image/s3,"s3://crabby-images/62956/6295650873b86e7fc5164eb894c42c146f871019" alt="A graphic saying 'an insider's guide to UX and UI with Figma, on Wednesday 1 November 1-2pm (GMT)"
data:image/s3,"s3://crabby-images/544cc/544cc5146ddae894c0421056ad6eaf46d1176f9a" alt="A group of people taking a selfie using the iPhone 16e."
data:image/s3,"s3://crabby-images/ba9b5/ba9b55098e4a68c727235b420317260bd10ca6c5" alt="AI trends predictions 2025"
data:image/s3,"s3://crabby-images/f60b4/f60b402bf3f4cdba2eac003b43f17b772199b4f9" alt="How we made Ada; A digitally animated scene depicts two women in a grand, antique-style library, with one pointing."
data:image/s3,"s3://crabby-images/b7c55/b7c557d1e1b23d0c9863718885716d4854f82074" alt="Cartoons of the 1950s - best animated movies of the 50s; A heartwarming animated scene depicts two canine characters sharing a meal of spaghetti and meatballs at a table outdoors."
data:image/s3,"s3://crabby-images/f80c6/f80c690ddbcb74ca6bfa67723422a6e1ab218785" alt="Making Paddington in Peru's character animation; a small bear in a red had sat in a jungle"
data:image/s3,"s3://crabby-images/e6fa1/e6fa14a324433c4a22464c4fead0f543be017ad6" alt="Making Paddington in Peru's ruined city; An elevated, high-angle view showcases a section of a stone ruin, likely a historical site, with a person navigating the crumbling structures."