Yesterday, we covered how to generate CSS animations for our Angular applications. Today, let’s see how to use such animations as route transitions when navigating from one route to the next:
data:image/s3,"s3://crabby-images/8dd01/8dd0150c64c39fdf925ee044b982c1244ff962c4" alt=""
The first thing we need to do is add the right providers for animations and transitions along with our routing config:
data:image/s3,"s3://crabby-images/e62d8/e62d8173eb2cd39bd53103302e1ff23ff2803201" alt=""
Then, we can create two different animations: One to exit the current “page” and one to enter the next “page.” In my example, I made two animations called entrance
and exit
using the CSS animation generator tool:
data:image/s3,"s3://crabby-images/9e5d0/9e5d044f2a21d8ba8f1d8571491a22e73840c4f1" alt=""
Angular has two specific selectors for view transitions: ::view-transition-old(root)
for the exit of the old page and ::view-transition-new(root)
for the entrance of the new page. Our next step is to “plug” our animations into these selectors:
data:image/s3,"s3://crabby-images/b56bb/b56bb5ff580bf7cacd779ec0466bd98237ba0961" alt=""
And… that’s it! Router animations are now in place. You can see the code for that example in action on Stackblitz.