博客
关于我
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/

你可能感兴趣的文章
php数组实现:哈希 +双向链表
查看>>
PHP数组排序函数array_multisort()函数详解(二)
查看>>
php数组的几个函数和超全局变量
查看>>
PHP文件锁
查看>>
php文本框输入制定文本,php – 当用户没有向文本框输入任何内容时...
查看>>
PHP时间戳和日期相互转换操作总结
查看>>
php时间戳知识点,php 时间戳函数总结与示例
查看>>
php更新数据库失败,php – 无法更新MySQL数据库
查看>>
php机器人聊天对话框,基于AIML的PHP聊天机器人
查看>>
PHP查找数组中最大值与最小值
查看>>
php查最大值,在PHP数组中查找最大值
查看>>
php标签筛选,关于PHP CodeIgniter框架中通过<a>标签和url做多条件分类筛选
查看>>
php根据年月日计算年龄
查看>>
RabbitMQ - 单机部署(超详细)
查看>>
php检查注册,PHP检查注册的电子邮件地址是一个’school.edu’地址
查看>>
php模拟发送GET和POST请求
查看>>
RabbitMQ - 以 MQ 为例,手写一个 RPC 框架 demo
查看>>
php模板引擎smarty
查看>>
php正则表达式模式
查看>>
php正则表达式的特殊字符含义
查看>>