CSS Transitions
Transition
Transitions are a nice way to add some interactive animations to your site. If you add a transition to an element, the browser will automatically animate between two states when they change. To try that you can combine what you just learned about classes and :hover
and add the transition
property to the mix:
Notice how you did not need to define an animation but still the browser animates between the two states? All we did is insert transition: 1s all;
which is the transition shorthand with only the first two values that are a transition-duration
of 1 second and the transition-property
of all
which means the browser will animate between all properties that have changed. You could also define different transitions for different properties, separated by a comma. Let’s go a little overboard with that and also use the other transition values:
See the Pen CSSclasses :hover by CSSclasses (@CSSclasses) on CodePen.
Notice how we used a very complicated transition shorthand here:
Let’s break it down: 1s width 0.2s ease-out
are the values that define the transition just for the width. The shorthand syntax is:
So in our example the width gets transitioned for one second, but only after a 0.2 second delay, with a timing function of ease-out. And then you use a comma and define the transition for the next property if you want to. Phew, sounds complicated, right? But as you can see in the example, you don’t always need to define all values, as they will have default values, as the 2s background-color transition shows. Don’t worry. It’s ok to look this up every time until you remember it.