CSS3 transform 属性基本使用方法

in css with 0 comment

前言

基本概念:transform 属性向元素应用 2D 或 3D 转换;该属性允许我们对元素进行旋转、缩放、移动或倾斜。

这两点是Transform的概念和应用场景,重点在于2D和3D的转换,那么呢?2D和3D的转换是有一定的数学基础的,为什么这么说呢?我们需要了解两个概念

image.png
CSS变换都是基于左手坐标系和透视投影。

常用属性主要有:Transform-origin(基准点),基于哪一个点来做变换,Transform-style(元素呈现方式2D还是3D),Rotate(旋转-度数),Scale(缩放-大小),Skew(倾斜-左右),Translate(移动-x/y轴),Perspective(透视)。

在实际变化过程在,transform不会脱离文档流,也不改变文档流的大小和位置,这个就和投影是一样道理。而电视机不同尺寸,是会改变屏幕大小的。

描述
none 定义不进行转换。
matrix(n,n,n,n,n,n) 定义 2D 转换,使用六个值的矩阵。
matrix3d(n,n,n,n,n,n,n,n,n,n,n,n,n,n,n,n) 定义 3D 转换,使用 16 个值的 4x4 矩阵。
translate(x,y) 定义 2D 转换。
translate3d(x,y,z) 定义 3D 转换。
translateX(x) 定义转换,只是用 X 轴的值。
translateY(y) 定义转换,只是用 Y 轴的值。
translateZ(z) 定义 3D 转换,只是用 Z 轴的值。
scale(x[,y]?) 定义 2D 缩放转换。
scale3d(x,y,z) 定义 3D 缩放转换。
scaleX(x) 通过设置 X 轴的值来定义缩放转换。
scaleY(y) 通过设置 Y 轴的值来定义缩放转换。
scaleZ(z) 通过设置 Z 轴的值来定义 3D 缩放转换。
rotate(angle) 定义 2D 旋转,在参数中规定角度。
rotate3d(x,y,z,angle) 定义 3D 旋转。
rotateX(angle) 定义沿着 X 轴的 3D 旋转。
rotateY(angle) 定义沿着 Y 轴的 3D 旋转。
rotateZ(angle) 定义沿着 Z 轴的 3D 旋转。
skew(x-angle,y-angle) 定义沿着 X 和 Y 轴的 2D 倾斜转换。
skewX(angle) 定义沿着 X 轴的 2D 倾斜转换。
skewY(angle) 定义沿着 Y 轴的 2D 倾斜转换。
perspective(n) 为 3D 转换元素定义透视视图。

具体用法

transform: rotate(45deg);

rotateX(angle),沿X轴3D旋转

transform: rotateX(45deg);

rotateY(angle) , 沿 Y 轴3D旋转

transform: rotateY(45deg);

rotateZ(angle) , 沿 Z 轴3D旋转

transform: rotateZ(45deg);

rotate3d(x, y, z, angle) , 3D旋转;接收四个参数,x y z 介于0-1之间,确定三维空间唯一坐标点,angle围绕原点与x y z 坐标点连线的旋转角度。
元素围绕着xyz在空间中确定的唯一坐标点和原点之间的连线旋转指定的角度,这就是rotate3D。

 transform: rotate3d(1,1,1,45deg);

transform: scale(2);//等价transform: scale(2,2);

scaleX(x) , 沿 X 轴缩放

transform: scaleX(2);


scaleY(y) , 沿 Y 轴缩放

transform: scaleY(2);

scaleZ(z) ,通过设置 Z 轴的值来定义 3D 缩放转换,沿 Z 轴缩放 - 单独使用时没有任何效果

transform: scaleZ(2);


scale3d(x, y, z) , 定义每个方向上的缩放 , Z方向单独使用时没有任何效果

transform: scale(2,2,2);

transform: skewX(45deg);

skewY(angle) - 沿 Y 轴的 2D 倾斜

transform: skewY(45deg);

skew(angle-x, angle-y) - 沿 X Y 轴的 2D 倾斜

transform: skewY(45deg, 45deg);

 transform: translateX(20px);

translateY(y) , 沿 Y 轴位移

 transform: translateY(20px);

translateZ(z) , 沿 Z 轴位移,需要配合perspective属性一起使用

 transform: translateZ(20px);

translate(x, y) , 沿 X Y 轴位移

 transform: translate(20px,20px);

translate3d(x, y, z) , 沿 X Y Z 轴位移

transform: translate(20px, 20px, 20px);

transform: perspective(200px);

transform-origin: x-axis y-axis z-axis;

transform-style: flat | preserve-3d  ;//其中flat值为默认值,表示所有子元素在2D平面呈现。

实际效果参考案例


<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <meta http-equiv="X-UA-Compatible" content="ie=edge">
    <title>Document</title>
    <style>

        *, *:after, *:before {
  box-sizing: border-box;
}

body {
  background: #F5F3F4;
  margin: 0;
  padding: 10px;
  font-family: 'Open Sans', sans-serif;
  text-align: center;
}

h1 {
  color: #4c4c4c;
  font-weight: 600;
  border-bottom: 1px solid #ccc;
}

h2, h4 {
  font-weight: 400;
  color: #4d4d4d;
}

.card {
  display: inline-block;
  margin: 10px;
  background: #fff;
  padding: 15px;
  min-width: 200px;
  box-shadow: 0 3px 5px #ddd;
  color: #555;
}
.card .box {
  width: 100px;
  height: 100px;
  margin: auto;
  background: #ddd;
  cursor: pointer;
  box-shadow: 0 0 5px #ccc inset;
}
.card .box .fill {
  width: 100px;
  height: 100px;
  position: relative;
  background: #03A9F4;
  opacity: .5;
  box-shadow: 0 0 5px #ccc;
  -webkit-transition: 0.3s;
  transition: 0.3s;
}
.card p {
  margin: 25px 0 0;
}

.rotate:hover .fill {
  -webkit-transform: rotate(45deg);
  transform: rotate(45deg);
}

.rotateX:hover .fill {
  -webkit-transform: rotateX(45deg);
  transform: rotateX(45deg);
}

.rotateY:hover .fill {
  -webkit-transform: rotateY(45deg);
  transform: rotateY(45deg);
}

.rotateZ:hover .fill {
  -webkit-transform: rotate(45deg);
  transform: rotate(45deg);
}

.scale:hover .fill {
  -webkit-transform: scale(2, 2);
  transform: scale(2, 2);
}

.scaleX:hover .fill {
  -webkit-transform: scaleX(2);
  transform: scaleX(2);
}

.scaleY:hover .fill {
  -webkit-transform: scaleY(2);
  transform: scaleY(2);
}

.skew:hover .fill {
  -webkit-transform: skew(45deg, 45deg);
  transform: skew(45deg, 45deg);
}

.skewX:hover .fill {
  -webkit-transform: skewX(45deg);
  transform: skewX(45deg);
}

.skewY:hover .fill {
  -webkit-transform: skewY(45deg);
  transform: skewY(45deg);
}

.translate:hover .fill {
  -webkit-transform: translate(45px, 1em);
  transform: translate(45px, 1em);
}

.translateX:hover .fill {
  -webkit-transform: translateX(45px);
  transform: translateX(45px);
}

.translateY:hover .fill {
  -webkit-transform: translateY(45px);
  transform: translateY(45px);
}

.matrix:hover .fill {
  -webkit-transform: matrix(2, 2, 0, 2, 45, 0);
  transform: matrix(2, 2, 0, 2, 45, 0);
}

.perspective-100 .box {
  -webkit-perspective: 100px;
  perspective: 100px;
}

.perspective-200 .box {
  -webkit-perspective: 200px;
  perspective: 200px;
}

.to-100-0-0 {
  -webkit-transform-origin: 100% 0 0;
          transform-origin: 100% 0 0;
}

.to-0-100-0 {
  -webkit-transform-origin: 0 100% 0;
          transform-origin: 0 100% 0;
}
    </style>
</head>
<body>
  
   
    <h1>Css3 Transform</h1>
    <!-- Rotate-->
    <div class="card">
      <div class="box rotate">
        <div class="fill"></div>
      </div>
      <p>rotate(45deg)  </p>
    </div>
    <div class="card">
      <div class="box rotateX">
        <div class="fill"></div>
      </div>
      <p>rotateX(45deg)</p>
    </div>
    <div class="card">
      <div class="box rotateY">
        <div class="fill"></div>
      </div>
      <p>rotateY(45deg)</p>
    </div>
    <div class="card">
      <div class="box rotateZ">
        <div class="fill"></div>
      </div>
      <p>rotateZ(45deg)  </p>
    </div>
    <!-- scale-->
    <div class="card">
      <div class="box scale">
        <div class="fill"></div>
      </div>
      <p>scale(2)</p>
    </div>
    <div class="card">
      <div class="box scaleX">
        <div class="fill"></div>
      </div>
      <p>scaleX(2)    </p>
    </div>
    <div class="card">
      <div class="box scaleY">
        <div class="fill"></div>
      </div>
      <p>scaleY(2)    </p>
    </div>
    <!-- skew-->
    <div class="card">
      <div class="box skew">
        <div class="fill"></div>
      </div>
      <p>skew(45deg, 45deg)  </p>
    </div>
    <div class="card">
      <div class="box skewX">
        <div class="fill"></div>
      </div>
      <p>skewX(45deg)</p>
    </div>
    <div class="card">
      <div class="box skewY">
        <div class="fill"></div>
      </div>
      <p>skewY(45deg)</p>
    </div>
    <!-- translate-->
    <div class="card">
      <div class="box translate">
        <div class="fill"></div>
      </div>
      <p>translate(45px)  </p>
    </div>
    <div class="card">
      <div class="box translateX">
        <div class="fill"></div>
      </div>
      <p>translateX(45px)</p>
    </div>
    <div class="card">
      <div class="box translateY">
        <div class="fill"></div>
      </div>
      <p>translateY(45px)</p>
    </div>
    <div class="card">
      <div class="box matrix">
        <div class="fill"></div>
      </div>
      <p> matrix(2, 2, 0, 2, 45, 0)</p>
    </div>
    <h4>Perspective : 100</h4>
    <div class="perspective-100">
      <div class="card">
        <div class="box rotateX">
          <div class="fill"></div>
        </div>
        <p>rotateX(90deg)</p>
      </div>
      <div class="card">
        <div class="box rotateY">
          <div class="fill"></div>
        </div>
        <p>rotateY(45deg)</p>
      </div>
    </div>
    <h4>Perspective : 200</h4>
    <div class="perspective-200">
      <div class="card">
        <div class="box rotateX">
          <div class="fill"></div>
        </div>
        <p>rotateX(90deg)</p>
      </div>
      <div class="card">
        <div class="box rotateY">
          <div class="fill"></div>
        </div>
        <p>rotateY(45deg)</p>
      </div>
    </div>
    <!-- transform origin-->
    <h2>Transform origin</h2>
    <div class="card">
      <div class="box rotate">
        <div class="fill to-100-0-0"></div>
      </div>
      <p>transform-origin : 100% 0 0  <br/>rotate(45deg)</p>
    </div>
    <div class="card">
      <div class="box rotate">
        <div class="fill to-0-100-0"></div>
      </div>
      <p>transform-origin : 0 100%  0<br/>rotate(45deg)</p>
    </div>
    <div class="card perspective-200">
      <div class="box rotateX">
        <div class="fill to-0-100-0"></div>
      </div>
      <p>transform-origin : 0 100%  0<br/>rotateX(45deg)</p>
    </div>
    <div class="card perspective-200">
      <div class="box rotateX">
        <div class="fill to-100-0-0"></div>
      </div>
      <p>transform-origin : 100% 0 0<br/>rotateX(45deg)</p>
    </div>
    <div class="card perspective-200">
      <div class="box rotateY">
        <div class="fill to-0-100-0"></div>
      </div>
      <p>transform-origin : 0 100%  0 <br/>rotateY(45deg)</p>
    </div>
    <div class="card perspective-200">
      <div class="box rotateY">
        <div class="fill to-100-0-0"></div>
      </div>
      <p>transform-origin : 100%  0 0<br/>rotateY(45deg)</p>
    </div>
    <div class="card">
      <div class="box scale">
        <div class="fill to-100-0-0"></div>
      </div>
      <p>transform-origin : 100%  0 0<br/>scale(2)</p>
    </div>
    <div class="card">
      <div class="box scale">
        <div class="fill to-0-100-0"></div>
      </div>
      <p>transform-origin : 0 100%  0<br/>scale(2)</p>
    </div>
    <div class="card">
      <div class="box scaleX">
        <div class="fill to-100-0-0"></div>
      </div>
      <p>transform-origin : 100%  0 0<br/>scaleX(2)</p>
    </div>
    <div class="card">
      <div class="box scaleX">
        <div class="fill to-0-100-0"></div>
      </div>
      <p>transform-origin : 0 100%  0<br/>scaleX(2)</p>
    </div>
    <div class="card">
      <div class="box scaleY">
        <div class="fill to-100-0-0"></div>
      </div>
      <p>transform-origin : 100%  0 0<br/>scaleY(2)</p>
    </div>
    <div class="card">
      <div class="box scaleY">
        <div class="fill to-0-100-0"></div>
      </div>
      <p>transform-origin : 0 100%  0<br/>scaleY(2)</p>
    </div>
</body>
</html>

注意

多个属性要想都生效,不能分开写,空格隔开好了。分开写应该只有最后一个生效,如下面这样不会生效:

transform: scaleY(2);
transform: scaleX(2);

写成

transform: scaleY(2) scaleX(2);

X O