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

你可能感兴趣的文章
Spring security之管理session
查看>>
paramiko模块
查看>>
param[:]=param-lr*param.grad/batch_size的理解
查看>>
spring mvc excludePathPatterns失效 如何解决spring拦截器失效 excludePathPatterns忽略失效 拦截器失效 spring免验证拦截器不起作用
查看>>
Spring Cloud 之注册中心 EurekaServerAutoConfiguration源码分析
查看>>
Parrot OS 6.2 重磅发布!推出全新 Docker 容器启动器
查看>>
Parrot OS 6.3 发布!全面提升安全性,新增先进工具,带来更高性能
查看>>
ParseChat应用源码ios版
查看>>
Part 2异常和错误
查看>>
Pascal Script
查看>>
Spring Boot集成Redis实现keyspace监听 | Spring Cloud 34
查看>>
Spring Boot中的自定义事件详解与实战
查看>>
Passport 密码模式
查看>>
Spring Boot(七十六):集成Redisson实现布隆过滤器(Bloom Filter)
查看>>
passport 简易搭配
查看>>
passwd命令限制用户密码到期时间
查看>>
Spring Boot 动态加载jar包,动态配置太强了!
查看>>
Spring @Async执行异步方法的简单使用
查看>>
PAT (Basic Level) Practice 乙级1021-1030
查看>>
PAT (Basic Level) Practice 乙级1031-1040
查看>>