一个炫酷的网页离不开css的transform、transition、animation三个属性,之前一直没有涉及到这块内容,刚好最近要做一个相关东西,趁此机会好好学一学这三个属性。

一、功能

实现元素的平移、旋转、缩放或倾斜。

二、 实现条件

只能转换由盒模型定位的元素。

三、 基本语法

  1. transform: none

    不应用任何变换

  2. transform: <transform-function>

    应用一个或多个<transform-function>值,以空格分开

     <transform-function>是啥?
    它是css中的一种数据类型,用于对元素的显示做变换。包括二维变换和三维变换。

四、 实现方式

1. 变形原点

在介绍转换之前需要先介绍一下变形原点,即转换的基点。

(1) 语法

  • transform-origin:初始值为(50%, 50%, 0),即center。其属性值有:

    • 一个值:

      必须是<length>, <percentage>, 或 left, center, right, top, bottom关键字中的一个。如果是<length>, <percentage>则表示x-offset,如果是keyword则表示其应有的意思。(即left、right是横向的,top、bottom是纵向的,center是中间的)

    • 两个值:

      • 一个值是<length>, <percentage>, 或 left, center, right关键字中的一个。表示距离和模型左侧的偏移值(即x-offset或x-offset-keyword)
      • 另一个值是<length>, <percentage>, 或 top, center, bottom关键字中的一个。表示距离和模型顶部的偏移值(即y-offset或y-offset-keyword)
        • 如果第一个值是<length>, <percentage>, left, right,则表示x轴的偏移,另一个值必须是y-offset或y-offset-keyword(top、bottom)。
        • 如果第一个值是top,bottom,则表示y轴的偏移,另一个值可以是<length>, <percentage>或 left, right表示x轴的偏移。
        • 如果第二个值是left或right,则第二个值表示x轴的,那么第一个值可以是, <percentage>或 top, bottom表示y轴的偏移。

          (听起来好绕hhh,但其实不复杂,意思就是两个值对于x,y的顺序没有规定死,可以自定义,一个表示x轴,那另一个值必须得用y轴的。但如果俩都是值的话,那第一个是x,第二个是y)
    • 三个值:

      • 前两个值同只有两个值时的用法相同。
      • 第三个值必须得是<length>。表示Z轴偏移量。
    • PS:keyword与value的值对应关系如下:

      • left —— 0%
      • center —— 50%
      • right —— 100%
      • top —— 0%
      • bottom —— 100%

(2) 示例

2. 平移

(1) 语法

  • 二维:translate(tx, ty)

    参数:

    • tx: 要移动矢量的横坐标。
    • ty: 要移动矢量的纵坐标。可以不写,默认为0。
  • 三维:translate3d(tx, ty, tz)

    参数:

    • tx: 移动矢量的横坐标。
    • ty: 移动矢量的纵坐标。
    • tz: 移动矢量的z轴坐标。不能使用百分比,否则会被认为无效属性!
  • translateX(t)、translateY(t)、translateZ(t)

    不用多说了,分别是translate(tx, 0)、translate(0, ty)、translate3d(0, 0, tz)的简写形式。

(2) 示例

<div class="transform-div"></div>

.transform-div {
width: 200px;
height: 200px;
background-color: orange;
transform: translate(300px, 10%);
}

3. 旋转

(1) 语法

  • 二维: rotate(a)

    • 参数:表示旋转的角度。正角表示顺时针旋转,负角表示逆时针旋转。
  • 三维: rotate3d(x, y, z, a)

    • 效果:3D旋转,绕着固定轴旋转。旋转轴由[x,y,z]向量定义,且过原点(由transform-origin定义)。[x,y,z]向量需要标准化,即三个坐标平方和为1,但如果没有标准化也没事,因为它在内部会被标准化,但对于不能被标准化的向量,如空向量,会导致旋转不被应用,但不会影响整个CSS属性。
    • 参数:
      • x、y、z: 顾名思义,分别是旋转向量的x、y、z坐标,都为<number>
      • a: 旋转角度。正值表示顺时针,负值表示逆时针。
  • rotateX(a), rotateY(a), rotateZ(a):分别是rotate3D(1, 0, 0, a), rotate3D(0, 1, 0, a), rotate3D(0, 0, 1, a)的简写。

(2) 示例

<div class="container">
<div class="line1"></div>
<div class="line2"></div>
<div class="transform-div"></div>
</div> .container {
width: 400px;
height: 400px;
border: 4px solid;
position: relative;
}
.transform-div {
position: absolute;
top: 50%;
left: 50%;
margin-top: -100px;
margin-left: -100px;
width: 200px;
height: 200px;
background-color: orange;
transition: all 1s;
transform: none;
opacity: 0.7;
} .transform-div:hover {
transform: rotateY(-45deg);
} .line1 {
position: absolute;
width: 100%;
height: 50%;
border-bottom: 2px solid;
} .line2 {
position: absolute;
top: 0;
height: 100%;
width: 50%;
border-right: 2px solid;
}

(截图看到的效果不是很清晰,可以复制上述代码看一下旋转效果)



4. 缩放

(1) 语法

  • 二维: scale(sx) 或 scale(sx, sy)

    • 效果:分别在x方向和在y方向放大or缩小一定的倍数,不同方向上的放大/缩小倍数可以不同。
    • 参数:
      • sx:缩放矢量的横坐标,为<number>值。
      • sy:缩放矢量的纵坐标,为<number>值。可以不存在,若不存在,则默认值与sx相同,即元素均匀缩放。
      • 值的大小在[-1,1]时,元素为缩放;大小在[-1,1]范围外时,为放大元素;当等于1时,什么都不做;当为负值时,执行点反射和大小修改。
  • 三维: scale3d(sx, sy, sz)

    • 参数:分别表示在横轴、纵轴、z轴的缩放大小。

5. 倾斜

(1) 语法

  • skew(ax) 或 skew(ax, ay)

    • 参数:ax、ay表示沿横、纵坐标扭曲元素的程度。是一个角度。
  • skewX(a)
    • 效果:水平拉伸,将元素每个点在水平方向上扭曲一定程度。
    • 参数:是一个角度,表示用于沿着横坐标扭曲元素的角度。
  • skewY(a)
    • 效果:垂直拉伸,将元素每个点在垂直方向上扭曲一定程度。
    • 参数:是一个角度,表示用于沿着纵坐标扭曲元素的角度。

(2) 示例

【补充】CSS角度单位:deg(度)、grad(梯度)、rad(弧度)、turn(圆、圈)

180deg = 200grad = 0.5turn = Π

6. 复合变换

  • 复合变换顺序:按从左到右的顺序。(这个顺序我自己没有很理解,我试了几个,只要没有旋转,无论顺序如何,得到的结果都是一样的,不懂原理,于是网上查了查,发现了这篇博客:https://www.cnblogs.com/xljzlw/p/4966798.html 值得参考。在旋转的时候,坐标系也会跟着旋转,所以旋转的顺序至关重要,如下示例:)

示例:

【解释】如上图所示,平移和旋转的顺序不同,得到的结果也不同。根本原因是,旋转时坐标系会跟着旋转。如下图:

【ps】只要不涉及旋转,那么顺序就无所谓,因为坐标系不会变。如果涉及到旋转,就要考虑顺序问题了,为了得到自己想要的效果,可以每次都把旋转放到最后。

【扩展】还可以直接在transform之后写变换矩阵:matrix()、matrix3d(),具体见文档。

CSS3转换(transform)基本用法介绍的更多相关文章

  1. css3中transform的用法

    transform:rotate旋转deg #box1{ -moz-transform:rotate(10deg); -webkit-transform:rotate(10deg); }transfo ...

  2. CSS3中box-shadow的用法介绍

    一般我们通过box-shadow来设置盒阴影,但是有些属性我们一般没有用到,这篇文章将对box-shadow属性进行逐个分析.语法 CSS Code复制内容到剪贴板 E {box-shadow:ins ...

  3. CSS3 转换2D transform

    Transform字面上就是变形,改变的意思.在CSS3中transform主要包括以下几种:旋转rotate.扭曲skew.缩放scale和移动translate以及矩阵变形matrix.下面我们一 ...

  4. css3 变形(transform)、转换(transition)和动画(animation)

    http://www.w3cplus.com/content/css3-transform/  在CSS3中transform主要包括以下几种:旋转rotate.扭曲skew.缩放scale和移动tr ...

  5. CSS3属性transform详解之(旋转:rotate,缩放:scale,倾斜:skew,移动:translate)

    CSS3属性transform详解之(旋转:rotate,缩放:scale,倾斜:skew,移动:translate)   在CSS3中,可以利用transform功能来实现文字或图像的旋转.缩放.倾 ...

  6. CSS3 2D Transform

    在 一个二维或三维空间,元素可以被扭曲.移位或旋转.只不过2D变形工作在X轴和Y轴,也就是大家常说的水平轴和垂直轴:而3D变形工作在X轴和Y轴之外, 还有一个Z轴.这些3D变换不仅可以定义元素的长度和 ...

  7. CSS3 transition/transform

    Transition 1.简写属性transition,可以包括四个属性,这四个属性的顺序按照下面介绍的顺序书写,即transition:property duration timing-functi ...

  8. A+B for Matrices 及 C++ transform的用法

    题目大意:给定两个矩阵,矩阵的最大大小是M*N(小于等于10),矩阵元素的值的绝对值小于等于100,求矩阵相加后全0的行以及列数. #include<iostream> using nam ...

  9. CSS3属性transform详解【转载】

    CSS3属性transform详解之(旋转:rotate,缩放:scale,倾斜:skew,移动:translate)   在CSS3中,可以利用transform功能来实现文字或图像的旋转.缩放.倾 ...

随机推荐

  1. 网络协议 SNMP- Windows10无简单SNMP协议服务器配置

    原因:Windwos10 1809后更新版本,无启动SNMP协议服务器可选配置项. 解决: 1.打开设置中的[开发人员模式],设置->更新与安全->开发者选项->开发人员模式 2.添 ...

  2. Linux如何设置用户登录超时(闲置时间)vi /etc/profile ... export TMOUT=900

    Linux如何设置用户登录超时(闲置时间) 转载莫负寒夏ai 最后发布于2019-08-08 15:04:22 阅读数 1897  收藏 展开 1. 针对所有用户 # vi /etc/profile ...

  3. linux系统瓶颈分析(精) CPU Memory IO Network

    linux系统瓶颈分析(精) linux系统瓶颈分析(精) (2013-09-17 14:22:00)   分类: linux服务器瓶颈分析 1.0 性能监控介绍性能优化就是找到系统处理中的瓶颈以及去 ...

  4. python基础之pip、.pyc、三元运算、进制、一切皆对象、可变与不可变类型

    一.pip(下载工具==yum) 1.重点(必须掌握的) 列出已安装的包 pip list 安装要安装的包 pip install xxx 安装特定版本 pip install django==1.1 ...

  5. 8.4 parted:磁盘分区工具

    parted     对于小于2TB的磁盘可以用fdisk和parted命令进行分区,这种情况一般采用flisk命令,但对于大于2TB的磁盘则只能用parted分区,且需要将磁盘转换为GPT格式. p ...

  6. 10.10 traceroute:追踪数据传输路由状况

    traceroute命令 用于显示网络数据包传输到指定主机的路径信息,追踪数据传输路由状况.默认数据包大小是60字节(IPv4)或80字节(IPv6),用户可另行设置.它与Windows下的trace ...

  7. 七、.net core(.NET 6)使用Serilog进行配置和实现日志记录

    使用Serilog来实现日志记录 先安装Serilog六件套神装包: 也可以对个别相应的包进行删除等,都是可以的.例如,标注的1是读取配置文件的,如果不需要通过配置文件进行操作,就可以使用这个包.2是 ...

  8. 华为MDC软件架构

    华为MDC软件架构 平台软件零层逻辑架构如下图,由基础层.功能层.应用层和服务层组成. 零层逻辑架构 从平台软件一层逻辑架构可以看出,MDC用了华为自研的越影操作系统.兼容Autosar标准的软件中间 ...

  9. 像Swing这种已经不太用的技术,大学还在教,到底要不要学?

    一直以来,写日常问题.前沿技术和架构思考类的文章比较多,今天为什么突然来说说Swing这个陈年老技术呢? 因为在CSDN上看到了这样的一篇文章: 可以看到作者对于学Swing还是挺愤怒的,不过确实Sw ...

  10. 用 Flutter 和 Firebase 轻松构建 Web 应用

    作者 / Very Good Ventures Team 我们 (Very Good Ventures 团队) 与 Google 合作,在今年的 Google I/O 大会上推出了 照相亭互动体验 ( ...