2.5 KiB
		
	
	
	
	
	
	
	
			
		
		
	
	title
| title | 
|---|
| Using CSS Transitions | 
Using CSS Transitions
CSS Transitions are used to create smooth movement of the elements in a website. They require less code than CSS animations, and tend to be less complex.
Transitions take an element from one CSS value to another. Here's an example:
.transition-me {
  width: 150px;
  height: 50px;
  background: blue;
}
.transition-me:hover {
  width: 100px;
  height: 150px;
  background: red;
}
Without a transition, this element will double in width as soon as the user hovers over it. But we might want a smoother movement. We can add a transition like so:
.transition-me {
  width: 150px;
  height: 50px;
  background: blue;
  transition: 0 0.3s all ease;
}
The transition CSS property is short-hand for several possible properties:
transition: transition-delay transition-duration transition-property transition-timing-function
transition-delay
This is the time before the transition begins in seconds,
div {
  transition-delay: 3s;
}
transition-duration
The duration of the transition.
div {
  transition-duration: 3s;
}
transition-property
This describes the CSS property which is transitioning, the default value all will mean that all properties that change will be transitioned. For multiple transition properties, use a comma-separated list.
div {
  transition-property: width, height;
  transition-property: all
}
transition-timing-function
The timing function lets us control the speed of the transition. Several keywords can be used with generic timing functions, or you can specify a cubic bezier.
div {
  transition-timing-function: linear;
  transition-timing-function: cubic-bezier(0,0,1,1);
}
For more options available in this property, check out the W3Schools page on transition-timing-function. Also there's a handy online cubic-bezier tool.