skewY()

Baseline 已广泛支持

此特性已相当成熟,可在许多设备和浏览器版本上使用。自 ⁨2015 年 7 月⁩以来,各浏览器均已提供此特性。

skewY() CSS 函数定义了一个在2D平面上沿垂直方向(y轴)倾斜元素的变换。其结果是 <transform-function> 数据类型。

试一试

transform: skewY(0);
transform: skewY(35deg);
transform: skewY(-0.06turn);
transform: skewY(0.352rad);
<section id="default-example">
  <img
    class="transition-all"
    id="example-element"
    src="/shared-assets/images/examples/firefox-logo.svg"
    width="200" />
</section>

这种变换是一种剪切映射(transvection),它通过一个特定角度沿垂直方向扭曲元素内的每个点。每个点的纵坐标(垂直方向,y轴坐标)会根据指定的角度和到原点的距离按比例修改;因此,一个点离原点越远,其添加的值就越大。

语法

css
skewY(a)

a

一个 <angle> 值,表示用于沿纵坐标(垂直方向,y轴)扭曲元素的角度。

笛卡尔坐标,在 ℝ^2 齐次坐标,在 ℝℙ^2 笛卡尔坐标,在 ℝ^3 齐次坐标,在 ℝℙ^3
(10tan(a)1)\left( \begin{array}{cc} 1 & 0 \\ \tan(a) & 1 \end{array} \right)
(100tan(a)10001)\left( \begin{array}{ccc} 1 & 0 & 0 \\ \tan(a) & 1 & 0 \\ 0 & 0 & 1 \end{array} \right)
(100tan(a)10001)\left( \begin{array}{ccc} 1 & 0 & 0 \\ \tan(a) & 1 & 0 \\ 0 & 0 & 1 \end{array} \right)
(1000tan(a)10000100001)\left( \begin{array}{cccc} 1 & 0 & 0 & 0 \\ \tan(a) & 1 & 0 & 0 \\ 0 & 0 & 1 & 0 \\ 0 & 0 & 0 & 1 \end{array} \right)
[1 tan(a) 0 1 0 0]

正式语法

<skewY()> = 
skewY( [ <angle> | <zero> ] )

示例

HTML

html
<div>Normal</div>
<div class="skewed">Skewed</div>

CSS

css
div {
  width: 80px;
  height: 80px;
  background-color: skyblue;
}

.skewed {
  transform: skewY(40deg);
  background-color: pink;
}

结果

规范

规范
CSS 变换模块级别 1
# funcdef-transform-skewy

浏览器兼容性

另见