Transforms
Learn how to transform our elements.
The transform
property
The transform
property allows us to visually manipulate elements by scaling, skewing, rotating, or translating them.
For example:
.element {
width: 30px;
height: 30px;
transform: scale(10);
}
Despite our declarations for height
and width
, the transform
property scales our element to be ten times their original size!
Transforms are especially fun when combined with animations.
Transform functions
We can use the following functions:
scale()
: scales the size of an element.skew()
: turns an element to the right or left.rotate()
: rotates the element clockwise.translate()
: repositions the element in a horizontal or vertical direction.perspective()
: sets the depth used in 3D transforms.
Let’s review each in more detail.
The scale()
function
The scale()
function is shorthand for the scaleX()
and scaleY()
functions.
The scaleX()
function resizes the element horizontally (x-axis) and the scaleY()
function resizes it vertically (y-axis).
For example, lets scale the width
of .element
by 2
(doubling its width) and reduce its height
by 0.5
(reducing its height by half):
.element {
transform: scale(2, 0.5);
}
The first parameter of the scale()
function is scaleX()
and the second is scaleY()
.
The skew()
function
The skew()
function tilts an element left or right. It’s also shorthand for the skewX()
and skewY()
functions. Below are some examples of the different ways we can skew an element.
To skew horizontally (x-axis):
transform: skewX(15deg);
To skew vertically (y-axis):
transform: skewY(15deg);
To skew along both axes simultaneously:
transform: skew(15deg, 15deg);
The rotate()
function
The rotate()
function rotates an element clockwise from its original position:
transform: rotate(25deg);
We can use a negative value to rotate it in the opposite direction:
transform: rotate(-25deg);
The translate()
function
The translate()
function shifts an element in a horizontal or vertical direction:
transform: translate(50px, 10px);
The example above moves the element 50px
(to the right) on its horizontal axis and 10px
(down) on its vertical axis.
Similarly with the scale()
and skew()
functions, the translate()
function is shorthand for the translateX()
and translateY()
functions:
transform: translateX(50px);
transform: translateY(10px);
We use negative values to move an element to the left or up.
We can use any valid length value, like px, em, or rem.
Combining multiple transforms
We can combine multiple transforms by separating each function with a space:
transform: rotateY(30deg) scaleX(2) translateX(200px);
3D transforms
With 3D transforms, we add a third z-axis, which adds depth.
The following functions control the z-axis:
- The
translateZ()
function. - The
rotateZ()
function. - The
scaleZ()
function.
For these, we have the corresponding shorthand functions translate3d()
, rotate3d()
, and scale3d()
for when we want to combine the translateX()
, translateY()
and translateZ()
functions.
The perspective
transform
The perspective
transform specifies the distance at which a 3D object appears from the viewer:
.element {
perspective: 100px;
}
Low values produce a more intense effect in comparison to high values.
The perspective-origin
transform
The perspective-origin
transform sets the position from which the user views the element:
.element {
perspective: 100px;
perspective-origin: left;
}
It positions the 3D object as if it’s being viewed differently.
Get hands-on with 1300+ tech skills courses.