在深入探讨 CSS 变形动画之前,让我们先探讨一下掌握它之后你可以实现哪些有趣的效果。

学习了 CSS 变形动画之后,你将能够为你的网页添加引人注目的动态效果,例如创建一个立体的 3D 魔方,或者设计一个引人入胜的旋转菜单。

这些仅仅是众多可能性中的一小部分,但或许可以勾起我们的学习兴趣。

一、什么是 CSS 变形动画?

CSS 变形动画是利用 CSS3 的 transform 属性创建的动画效果。它可以使元素旋转、缩放、倾斜甚至翻转,让静态的网页元素动起来,为用户带来更加丰富的交互体验。

坐标系统

首先我们要学习的变形动画,想达到在上图中出现的 3D 效果单纯的 X 与 Y 两个轴是实现不了的,还需要加入一条纵深轴,即 Y 轴的参与才有一个 3D 的视觉感受。

那么如何来理解 X,Y,Z 这三条轴的关系呢?可以看一下下面这张图。

  • X 轴代表水平轴
  • Y 轴代表垂直轴
  • Z 轴代表纵深轴

X 和 Y 轴都非常好理解,怎么理解这个 Z 轴呢?

CSS 的中文名称叫做层叠样式表,那么它肯定是一层一层的。之前学习过 z-index 就是用来设置层的优先级,优先级越高越在上面,也可以理解为离我们肉眼越近,它把优先级低的层给盖住了,所以 Z 轴可以理解为我们观察的视角与被观察物体之间的一条轴。

  • Z 轴数值越大,说明观测距离越远。
  • Z 轴的数值可以无限大,所以设置的时候一定要小心。

二、变形操作

使用 transform 来控制元素变形操作,包括控制移动、旋转、倾斜、3D 转换等。

下面我们通过一些例子来演示一下,比较常用的变形操作:

2.1 位移 translate()

translate() 函数可以将元素向指定的方向移动,类似于 position 中的 relative。或以简单的理解为,使用 translate() 函数,可以把元素从原来的位置移动,而不影响在 X、Y 轴上的任何 Web 组件。

想象一下,当你滚动页面时,一个元素平滑地从一个位置滑向另一个位置,这种流畅的过渡效果可以大大提升用户体验。

translate 我们分为三种情况:
1)translate(x,y) 水平方向和垂直方向同时移动(也就是 X 轴和 Y 轴同时移动)
2)translateX(x) 仅水平方向移动(X 轴移动)
3)translateY(Y) 仅垂直方向移动(Y 轴移动)

实例演示: 通过 translate() 函数将元素向 Y 轴下方移动 50px,X 轴右方移动 100px。

HTML 代码:

<div class="wrapper">
  <div>我向右向下移动</div>
</div>

CSS 代码:

.wrapper {
  width: 200px;
  height: 200px;
  border: 2px dotted red;
  margin: 20px auto;
}
.wrapper div {
  width: 200px;
  height: 200px;
  line-height: 200px;
  text-align: center;
  background: orange;
  color: #fff;
  -webkit-transform: translate(50px,100px);
  -moz-transform:translate(50px,100px);
  transform: translate(50px,100px);
}

演示结果:

2.2 旋转 rotate()

旋转 rotate() 函数通过指定的角度参数使元素相对原点进行旋转。旋转不仅可以是固定的度数,还可以是动态变化的,创造出无限的可能性。

它主要在二维空间内进行操作,设置一个角度值,用来指定旋转的幅度。如果这个值为正值,元素相对原点中心顺时针旋转;如果这个值为负值,元素相对原点中心逆时针旋转。如下图所示:

HTML 代码:

<div class="wrapper">
  <div></div>
</div>

CSS 代码:

.wrapper {
  width: 200px;
  height: 200px;
  border: 1px dotted red;
  margin: 100px auto;
}
.wrapper div {
  width: 200px;
  height: 200px;
  background: orange;
  -webkit-transform: rotate(45deg);
  transform: rotate(45deg);
}

演示结果:

2.3 扭曲 skew()

扭曲 skew() 函数能够让元素倾斜显示。这种效果常常用于模拟速度感或者倾斜的视觉效果。

它可以将一个对象以其中心位置围绕着 X 轴和 Y 轴按照一定的角度倾斜。这与 rotate() 函数的旋转不同,rotate() 函数只是旋转,而不会改变元素的形状。skew() 函数不会旋转,而只会改变元素的形状。

Skew() 具有三种情况:
1)skew(x,y) 使元素在水平和垂直方向同时扭曲(X 轴和 Y 轴同时按一定的角度值进行扭曲变形);

第一个参数对应 X 轴,第二个参数对应 Y 轴。如果第二个参数未提供,则值为 0,也就是 Y 轴方向上无斜切。

2)skewX(x) 仅使元素在水平方向扭曲变形(X 轴扭曲变形);

3)skewY(y) 仅使元素在垂直方向扭曲变形(Y 轴扭曲变形)。

示例演示:通过 skew()函数将长方形变成平行四边形。HTML 代码:

<div class="wrapper">
  <div>我变成平形四边形</div>
</div>

CSS 代码:

.wrapper {
  width: 300px;
  height: 100px;
  border: 2px dotted red;
  margin: 30px auto;
}
.wrapper div {
  width: 300px;
  height: 100px;
  line-height: 100px;
  text-align: center;
  color: #fff;
  background: orange;
  -webkit-transform: skew(45deg);
  -moz-transform:skew(45deg) 
  transform:skew(45deg);
}

演示结果:

2.4 缩放 scale()

缩放 scale() 函数 让元素根据中心原点对对象进行缩放。这不仅可以用来模拟放大镜效果,还可以创造出元素的进入和退出动画,比如一个图片慢慢缩小直至消失。

缩放 scale 具有三种情况:

1) scale(X,Y) 使元素水平方向和垂直方向同时缩放(也就是 X 轴和 Y 轴同时缩放)。

例如:

div:hover {
  -webkit-transform: scale(1.5,0.5);
  -moz-transform:scale(1.5,0.5)
  transform: scale(1.5,0.5);
}

注意:Y 是一个可选参数,如果没有设置 Y 值,则表示 X,Y 两个方向的缩放倍数是一样的。2)scaleX(x) 元素仅水平方向缩放(X 轴缩放)

3)scaleY(y) 元素仅垂直方向缩放(Y 轴缩放)

HTML 代码:

<div class="wrapper">
  <div>我将放大1.5倍</div>
</div>

CSS 代码:

.wrapper {
  width: 200px;
  height: 200px;
  border:2px dashed red;
  margin: 100px auto;
}
.wrapper div {
  width: 200px;
  height: 200px;
  line-height: 200px;
  background: orange;
  text-align: center;
  color: #fff;
}
.wrapper div:hover {
  opacity: .5;
  -webkit-transform: scale(1.5);
  -moz-transform:scale(1.5)
  transform: scale(1.5);
}

演示结果:

注意: scale() 的取值默认的值为 1,当值设置为 0.01 到 0.99 之间的任何值,作用使一个元素缩小;而任何大于或等于 1.01 的值,作用是让元素放大。

想要快速入门前端开发吗?推荐一个前端开发基础课程,这个老师讲的特别好,零基础学习无压力,知识点结合代码,边学边练,可以免费试看试学,还有各种辅助工具和资料,非常适合新手!点这里前往学习哦!

2.5 矩阵 matrix()

matrix() 是一个含六个值的 (a,b,c,d,e,f) 变换矩阵,用来指定一个 2D 变换,相当于直接应用一个 [a b c d e f] 变换矩阵。就是基于水平方向(X 轴)和垂直方向(Y 轴)重新定位元素。

此属性值使用涉及到数学中的矩阵,我在这里只是简单的说一下 CSS3 中的 transform 有这么一个属性值,如果需要深入了解,需要对数学矩阵有一定的知识。

示例演示:通过 matrix() 函数来模拟 transform 中 translate() 位移的效果。

HTML 代码:

<div class="wrapper">
  <div></div>
</div>

CSS 代码:

.wrapper {
  width: 300px;
  height: 200px;
  border: 2px dotted red;
  margin: 40px auto;
}
.wrapper div {
  width:300px;
  height: 200px;
  background: orange;
  -webkit-transform: matrix(1,0,0,1,50,50);
  -moz-transform:matrix(1,0,0,1,50,50);
  transform: matrix(1,0,0,1,50,50);
}

演示结果:

2.6 原点 transform-origin

任何一个元素都有一个中心点,默认情况之下,其中心点是居于元素 X 轴和 Y 轴的 50% 处。如下图所示:

在没有重置 transform-origin 改变元素原点位置的情况下,CSS 变形进行的旋转、位移、缩放,扭曲等操作都是以元素自己中心位置进行变形。

但很多时候,我们可以通过 transform-origin 来对元素进行原点位置改变,使元素原点不在元素的中心位置,以达到需要的原点位置。transform-origin 取值和元素设置背景中的 background-position 取值类似,如下表所示:

示例演示:通过 transform-origin 改变元素原点到左上角,然后进行顺时旋转 45 度。

HTML 代码:

<<div class="wrapper">
  <div>原点在默认位置处</div>
</div>
<div class="wrapper transform-origin">
  <div>原点重置到左上角</div>
</div>

CSS 代码:

.wrapper {
  width: 300px;
  height: 300px;
  float: left;
  margin: 100px;
  border: 2px dotted red;
  line-height: 300px;
  text-align: center;
}
.wrapper div {
  background: orange;
  -webkit-transform: rotate(45deg);
  transform: rotate(45deg);
}
.transform-origin div {
  -webkit-transform-origin: left top;
  transform-origin: left top;
}

演示结果:

以上就是 css 动画中几种基本的变形技巧了,掌握这些我们可以操控我们的网页元素实现我们想要的一些基本动画效果。

在这个充满创造力的时代,CSS 变形动画是每个前端开发者必备的技能。它不仅能提升用户体验,更能激发设计师和开发者的创意火花。所以,不妨尝试一下,让你的网页动起来,给用户留下深刻的印象吧!