DEV Community

Cover image for Web Animation with CSS - Learn the Basics
Suraj Vishwakarma for Basecamp Community

Posted on • Originally published at surajondev.com

Web Animation with CSS - Learn the Basics

Introduction

Animation makes a web page more interesting, attractive, and interactive than any static web page that doesn't contain any animation. A ton of websites we visit each day but very few stand out in terms of the pure frontend. Animation in web pages makes our website stand out in a pool of websites.

So, I am going to start a series called Web Animation. In this, we will learn Web Animation using CSS from scratch. We will learn the various concept from basic to advance.

Starting with the first topics in web Animation are transform, transition, and keyframes.

Transform

Transform property helps you to add a 2D or 3D transformation to an element. It allows you to scale, rotate, move, etc. an element. Read here to know about all the values for transform property.

Code

{
 transform : scale(1.5,1.5)
}
Enter fullscreen mode Exit fullscreen mode

CodePen Example

In the above example, the element with the class name smallcircle is given the transform property. We applied the translate value to change the location of the element. smallcircle and bigcircle together appears as concentric circles.


Transition

CSS transition property allows you to change the property of the element over a particular duration. As a value, we passed the property name to which we want to apply the transition. We can define duration, delay of transition separated by a single space in terms of seconds. You can learn about different values related to transition here

Code

{
 transition : background-color 1s;
}
Enter fullscreen mode Exit fullscreen mode

CodePen Example

In the above codepen, we can see the circle is transitioning from left to right with a change in the color of the circle. We have applied transition property to the div with the class name circle. As a value, we have passed the property on which we want to apply transition with the duration of transition next to it. We can give a different value for the transition that can be separated by a comma(,). To trigger the transition we have used a hover selector. This has to define property and value to which transition happens from the initial value.


Keyframe

Keyframe allows you to control the flow of animation by giving different CSS styles set to different animation stages. It is the transition from one set of CSS styles to another. You can change the different properties of an element multiple times. You can use from and to to define the start and end of transition respectively. You can also use percentage to define multiple changes during different stages of transition, 0% to 100% percent are used. 0% for starting and 100% for ending the transition.

Code

@keyframe move{
 from{
   background-color:red;
}
 to{
   background-color:green;
}
Enter fullscreen mode Exit fullscreen mode

Codepen Example

In the above codepen, we have three circles that are animating in a loop. We have define animation property such as animation-name, animation-duration, animation-iteration-count, and animation-timing-function. For transition we have a keyframe define using @. After defining the @keyframe, we have the name of the animation that is bounce and bounce1. As to define animation we have used percentage. We have 50% to define our CSS style for transition. As there are no 0% and 100% that makes starting and ending value for animation as the initial value of the property.

Last Note

Now with the help of transform, transition, and keyframe we can add basic animation to our web pages.

I hope, with this new power of animation, you will apply it in your next project to make it more interactive.

Thank You for reading the blog post.

Discussion (4)

Collapse
lucaargentieri profile image
Luca Argentieri

Really interesting, I'm looking forward to the next post 🔥

Collapse
surajondev profile image
Suraj Vishwakarma Author

Thanks, for your appreciation ☺️

Collapse
rameshkmunjal profile image
RAMESH KUMAR MUNJAL

Interesting and informative. Thanks. Keep it up

Collapse
surajondev profile image
Suraj Vishwakarma Author

Thank You☺️