data:image/s3,"s3://crabby-images/ef09e/ef09e7e016e61bf37ce0e07e67eec84f67e94a3a" alt="ubuntu | Lava Lamp Lab ubuntu"
Help! I’ve Had To SSH Into A Linux Box For The First Time (Part 3)
September 12, 2022data:image/s3,"s3://crabby-images/657ab/657ab762c922b1048668b425b49007fca555f90c" alt="misconceptions about software development | Lava Lamp Lab misconceptions about software development"
Misconceptions About Software Development
September 26, 2022data:image/s3,"s3://crabby-images/50b63/50b63f4fa1b5c2e501f3d94b6312166be4d04f46" alt="animation | Lava Lamp Lab animation"
Adding animation effects could be done in a number of ways, namely CSS/SASS or a library, but Angular could also do this plus the benefit of reusability and easy implementation.
Starting Point
Firstly we have to make sure we have the animations package installed (creating a new project usually has this added already).
Install the animations package:
npm install --save @angular/animations
Then just add the BrowserAnimationModule to you app's main .module file.
Now the fun starts
Lets define an animation (I decided to create a separate module file to hold all my animation styles).
Note that I also had to import all the animation methods used in my logic.
All of these built-in methods all have an important task:
- trigger - accepts a name for the animation trigger and an array of state and transition methods to configure the animation.
- style - CSS styles to be applied.
- transition - specifies the configuration for transitioning between the different states and its direction.
- animate - specifies the duration and any additional CSS animation properties such as easing.
Let's Implement
On the page/component I want to use my animation, import it into the component class;
and add it to the component decorator using the animations property.
Now simply add this animation to any div or directive you would like to animate like so;
And that's how easy it is to add animations in an Angular app.
Note how easy it would be to reuse this animation in a different component or event import and add more than one animation to the same component.