博客
关于我
CSS3新特性——2D转换技术
阅读量:247 次
发布时间:2019-03-01

本文共 1391 字,大约阅读时间需要 4 分钟。

2D转换概念

2D转换

2D转换是改变标签在二维平面上的位置和形状。常见的2D转换方法包括移动、旋转和缩放。

2D转换 - 移动

移动是2D转换中最基本的操作,主要用于水平和垂直方向上的位移。

  • transform: translate(x, y)
  • transform: translateX(n)
  • transform: translateY(n)

关键点:

  • 2D的移动主要是指水平、垂直方向上的移动。
  • translate的最大优点是不会影响其他元素的位置。
  • translate中的100%单位,是相对于本身的宽度和高度来进行计算的。
  • 行内标签没有效果。

代码示例:

div {    background-color: lightseagreen;    width: 200px;    height: 100px;    transform: translate(100px, 100px); /* 水平垂直移动100px */    transform: translateX(100px); /* 水平移动100px */    transform: translateY(100px); /* 垂直移动100px */}

2D转换 - 旋转

旋转是让元素在二维平面内顺时针或逆时针旋转。

语法:

transform: rotate(角度),单位是 deg

关键点:

  • 角度为正时,顺时针方向旋转。
  • 角度为负时,逆时针方向旋转。
  • 默认旋转的中心点是元素的中心点。

代码示例:

img:hover {    transform: rotate(360deg); /* 顺时针旋转360度,相当于没有旋转 */}

设置旋转中心点(transform-origin):

transform-origin 用于设置旋转的中心点,默认是元素的中心点(50% 50%)。

语法:

transform-origin: x y;

  • x 和 y 可以是像素值或方位名词(topbottomleftrightcenter)。

代码示例:

div {    transform-origin: 100px 100px; /* 自定义旋转中心 */}

2D转换 - 缩放

缩放用于控制元素的放大与缩小。

语法:

transform: scale(x, y)

关键点:

  • x 和 y 之间使用逗号分隔。
  • 如果只写一个参数,第二个参数会和第一个参数一致。
  • scale(1,1) 表示不改变大小。
  • scale(2,2) 表示放大两倍。
  • scale(0.5,0.5) 表示缩小两倍。
  • scale 的最大优势是可以设置转换中心点缩放,默认以中心点缩放。

代码示例:

div:hover {    transform: scale(0.5, 0.5); /* 缩小50% */}

2D转换 - 综合写法及顺序问题

关键点:

  • 同时使用多个转换时,格式为 transform: translate() rotate() scale()
  • 转换的顺序会影响到效果(先旋转会改变坐标轴方向)。
  • 如果同时有位置或其他属性要放到最前面。

代码示例:

div:hover {    transform: translate(200px, 0) rotate(360deg) scale(1.2); /* 综合使用 */}

转载地址:http://atux.baihongyu.com/

你可能感兴趣的文章
numpy转PIL 报错TypeError: Cannot handle this data type
查看>>
Numpy闯关100题,我闯了95关,你呢?
查看>>
nump模块
查看>>
Nutch + solr 这个配合不错哦
查看>>
NuttX 构建系统
查看>>
NutUI:京东风格的轻量级 Vue 组件库
查看>>
NutzCodeInsight 2.0.7 发布,为 nutz-sqltpl 提供友好的 ide 支持
查看>>
NutzWk 5.1.5 发布,Java 微服务分布式开发框架
查看>>
NUUO网络视频录像机 css_parser.php 任意文件读取漏洞复现
查看>>
NUUO网络视频录像机 upload.php 任意文件上传漏洞复现
查看>>