CSS Transitions
Let's use CSS transitions in this lesson.
We'll cover the following
When we add the new CSS class to our elements in the previous example, the transform property changes the orientation of the element on the screen. However, there are other ways we can change the element. Our new classes could specify a background color, change the margin, add a border, and so on. There are many properties of a DOM element that can change with the addition of new CSS classes. Generically, we can call these property changes transitions.
CSS provides what you can think of as a meta-property called transition
. The transition
property allows you to change the behavior of the CSS element when one of its display properties changes. The default behavior is that the property changes instantly.
Implementing trasitions
It doesn’t take much syntax to use the transition
property to make our arrows; all we need to do is add one line to the definition of the background-arrow
CSS class in application.scss
:
.background-arrow {
background-image: url("../images/arrow.svg");
width: 25px;
height: 25px;
transition: all 0.3s ease-in-out;
// and so on
}
The new line here is transition: all 0.3s ease-in-out;
, which specifies that we want properties to transition.
The syntax of the transition
property has up to four elements:
- The first is the name of the property being observed, or the special words
all
ornone
. The rotation angle, strictly speaking, doesn’t have a property, so it can only be captured usingall
. But if you only wanted to transition on changes tobackground-color
ormargin
for example, you could limit the change by only including one property. There’s a specific list of what can be categorized as a transition, but basically, any change where all the steps between the values can be listed is fair game. That means that properties that have discrete enumerated values, likedisplay
, can’t be transitioned, and you also usually can’t transition to or from magic values like height or widthauto
. - The second element is the amount of time you want the transition to take, which is defined either in seconds (
s
) or milliseconds (ms
). - The third element is a timing function that determines the rate at which the value changes across the transition. The default is
linear
, meaning the rate is the same for the entire time. Our code usesease-in-out
, which slows the rate of change at the beginning and end of the transition, and speeds it up across the middle.
There are other timing functions, should you want to investigate.
- The last element, which our code doesn’t have, is a delay—the amount of time to wait before starting the transitions.
What our code is saying is that when any property in our DOM element changes, spread that change out over 0.3 seconds, and use an ease in and ease out function to manage the rate of that change.
And just like that, when we click those little buttons, the transition from down to up and back is animated. This effect is a little hard to get across in a screen shot, but trust me on this.
Animation Side Effects
A fun side effect of the current implementation is that the initial transition from the basic image pointing right to the initial down state might also be animated, leading to all the arrows turning down at page load. I find this kind of charming, but you could also get rid of it by either starting with a real down pointing image or only adding the transition to the DOM element after the page has loaded.
Transitions don’t have to be paired with transformations. Any change in values can be transitioned. A common use of this is to change a value on the hover
pseudo-element. For example, let’s add this definition:
Get hands-on with 1300+ tech skills courses.