skew()
Baseline Widely available
This feature is well established and works across many devices and browser versions. It’s been available across browsers since July 2015.
The skew() CSS function defines a transformation that skews an element on the 2D plane. Its result is a <transform-function> data type.
Try it
transform: skew(0); transform: skew(15deg, 15deg); transform: skew(-0.06turn, 18deg); transform: skew(0.312rad); <section id="default-example"> <img class="transition-all" id="example-element" src="/shared-assets/images/examples/firefox-logo.svg" width="200" /> </section> This transformation is a shear mapping (transvection) that distorts each point within an element by a certain angle in the horizontal and vertical directions. The effect is as if you grabbed each corner of the element and pulled them along a certain angle.
The coordinates of each point are modified by a value proportionate to the specified angle and the distance to the origin. Thus, the farther from the origin a point is, the greater the value added to it.
Syntax
skew(ax) skew(ax, ay) Values
ax-
Is an
<angle>representing the angle to use to distort the element along the x-axis. ayOptional-
Is an
<angle>representing the angle to use to distort the element along the y-axis. If not defined, its default value is0, resulting in a purely horizontal skewing.
| Cartesian coordinates on ℝ^2 | Homogeneous coordinates on ℝℙ^2 | Cartesian coordinates on ℝ^3 | Homogeneous coordinates on ℝℙ^3 |
|---|---|---|---|
| | | | |
[1 tan(ay) tan(ax) 1 0 0] |
Formal syntax
<skew()> =
skew( [ <angle> | <zero> ] , [ <angle> | <zero> ]? )
Examples
>Skewing on the x-axis only
HTML
<div>Normal</div> <div class="skewed">Skewed</div> CSS
body { margin: 20px; } div { width: 80px; height: 80px; background-color: skyblue; } .skewed { transform: skew(10deg); /* Equal to skewX(10deg) */ background-color: pink; } Result
Skewing on both axes
HTML
<div>Normal</div> <div class="skewed">Skewed</div> CSS
body { margin: 20px; } div { width: 80px; height: 80px; background-color: skyblue; } .skewed { transform: skew(10deg, 10deg); background-color: pink; } Result
Specifications
| Specification |
|---|
| CSS Transforms Module Level 1> # funcdef-transform-skew> |
Browser compatibility
Loading…