CSS3中的transform属性进行2D和3D变换的基本用法


Posted in HTML / CSS onMay 12, 2016

transform 2D
之前有看到google将搜寻的页面倾斜,这个功能透过CSS3的transform就可以达成
CSS3 2D transform特性可以旋转、倾斜、放大缩小和移动元素,对网页的视觉观感上提供很大的帮助
使用方法:

CSS Code复制内容到剪贴板
  1. transform: transform-function;   
  2. -webkit-transform: transform-function; /* Safari and Chrome */  
  3. -moz-transform: transform-function; /* Firefox */  
  4. -o-transform: transform-function; /* Opera */  
  5. -ms-transform:transform-function; /* IE9以上 */  

变形函式 transform-function:
函式里的θ参数要有单位,有三种单位可以使用:deg (角度) 、 rad (弧度) 、 grad (梯度)。
1.rotate(θ):以参考点为中心轴 2D 旋转 θ 度。
2.skew(θx,θy):以参考点为中心轴沿着横向倾斜 θx 度、纵向倾斜 θy 度( 可以拆开成skewX(θ)和skewY(θ) )
3.scale(x,y):指定元素由参考点 2D 横向缩放 x 倍、纵向缩放 y 倍( 可以拆开成scaleX(x)和scaleY(y),此函式的参数不需要单位 )
4.translate(x,y):指定元素由参考点 2D 横向移动 x 距离、纵向移动 y 距离( 可以拆开成translateX(x)和translateY(y),此函式的参数单位为px )
5.matrix(a,b,c,d,e,f):指定元素由参考点依据数学变形矩阵 (transformation matrix) 的 6 个参数值产生 2D 变形( 此函式的参数为数字,不需要单位 )
Sample

JavaScript Code复制内容到剪贴板
  1. /* Safari and Chrome 网页倾斜50度 */  
  2. -webkit-transform: rotate(50deg);  

 
transform 3D & perspective
CSS3的transform可以做2D的操作,当然也有3D
但需要再一个拥有perspective属性的父元素才能显现3D的效果
例如:

XML/HTML Code复制内容到剪贴板
  1. <div id="div1"><!-- perspective -->  
  2.   <div id="div2">3D</div><!-- transform -->  
  3. </div>  

perspective属性固名思义就是透视的意思;该属性可以定义3D视觉的角度,让底下子元素使用3D特效时能够完整显示。
perspective使用方法
perspective:150px;

XML/HTML Code复制内容到剪贴板
  1. /* 目前并非所有浏览器皆支援 */   
  2. -webkit-perspective:150px;   
  3. -moz-perspective:150px;  

另外还有个属性叫perspective-origin
功能是用来定义X和Y轴为基础的3D位置(定义初始位置)
perspective-origin使用方法:
属性值:(x轴:left、center、right、长度、百分比) (y轴:top、center、bottom、长度、百分比)

CSS Code复制内容到剪贴板
  1. /* perspective-origin 参数预设是50% 50% */  
  2. -webkit-perspective-origin: 40% 60%;/* Safari and Chrome */  
  3. -webkit-perspective-origin: 40px 60px;/* Safari and Chrome */  
  4. -moz-perspective-origin:left bottombottom/* Firefox */  

注意:perspective和perspective-origin受影响的是子元素,而非元素本身
最后就可以对div做3D的效果(rotateX和rotateY)

CSS Code复制内容到剪贴板
  1. -webkit-transform: rotateX(290deg);   
  2. -webkit-transform: rotateY(290deg);   
  3. -moz-transform: rotateX(290deg);   
  4. -moz-transform: rotateY(290deg);  

 
 
 
 
 

HTML / CSS 相关文章推荐
CSS3教程(10):CSS3 HSL声明设置颜色
Apr 02 HTML / CSS
基于CSS3实现图片模糊过滤效果
Nov 19 HTML / CSS
关于css中margin的值和垂直外边距重叠问题
Oct 27 HTML / CSS
你不知道的5个HTML5新功能
Jun 28 HTML / CSS
HTML5 语义化结构化规范化
Oct 17 HTML / CSS
自定义html标记替换html5新增元素
Oct 17 HTML / CSS
HTML5 Canvas像素处理使用接口介绍
Dec 02 HTML / CSS
HTML5 文件域+FileReader 分段读取文件并上传到服务器
Oct 23 HTML / CSS
Canvas制作的下雨动画的示例
Mar 06 HTML / CSS
html5调用摄像头实例代码
Jun 28 HTML / CSS
CSS使用Flex和Grid布局实现3D骰子
Aug 05 HTML / CSS
CSS 实现磨砂玻璃(毛玻璃)效果样式
May 21 HTML / CSS
CSS3制作气泡对话框的实例教程
May 10 #HTML / CSS
详解CSS3的box-shadow属性制作边框阴影效果的方法
May 10 #HTML / CSS
解决CSS3的opacity属性带来的层叠顺序问题
May 09 #HTML / CSS
详解CSS3的opacity属性设置透明效果的用法
May 09 #HTML / CSS
CSS3中使用RGBa来调节透明度的教程
May 09 #HTML / CSS
使用CSS3编写灰阶滤镜来制作黑白照片效果的方法
May 09 #HTML / CSS
CSS超出文本指定宽度用省略号代替和文本不换行
May 05 #HTML / CSS
You might like
wamp下修改mysql访问密码的解决方法
2013/05/07 PHP
php cli换行示例
2014/04/22 PHP
php中mt_rand()随机数函数用法
2014/11/24 PHP
Laravel构建即时应用的一种实现方法详解
2017/08/31 PHP
PHP7 字符串处理机制修改
2021/03/09 PHP
PHP7 弃用功能
2021/03/09 PHP
JavaScript 对话框和状态栏使用说明
2009/10/25 Javascript
jQuery EasyUI API 中文文档 - ValidateBox验证框
2011/10/06 Javascript
JavaScript 5 新增 Array 方法实现介绍
2012/02/06 Javascript
仅IE支持clearAttributes/mergeAttributes方法使用介绍
2012/05/04 Javascript
jquery1.83 之前所有与异步列队相关的模块详细介绍
2012/11/13 Javascript
js实现两个值相加alert出来精确到指定位
2013/09/25 Javascript
ie8本地图片上传预览示例代码
2014/01/12 Javascript
js中settimeout方法加参数的使用实例
2014/02/27 Javascript
Node.js中的缓冲与流模块详细介绍
2015/02/11 Javascript
JavaScript实现cookie的写入、读取、删除功能
2015/11/05 Javascript
Angularjs注入拦截器实现Loading效果
2015/12/28 Javascript
jquery插件之文字间歇自动向上滚动效果代码
2016/02/25 Javascript
AngularJS基础 ng-mouseleave 指令详解
2016/08/02 Javascript
基于jQuery实现简单人工智能聊天室
2017/02/10 Javascript
vue利用better-scroll实现轮播图与页面滚动详解
2017/10/20 Javascript
vue 实现滚动到底部翻页效果(pc端)
2019/07/31 Javascript
Javascript Worker子线程代码实例
2020/02/20 Javascript
[01:04:05]VG vs Newbee 2018国际邀请赛小组赛BO2 第一场 8.17
2018/08/20 DOTA
python实现马耳可夫链算法实例分析
2015/05/20 Python
Python实现简单HTML表格解析的方法
2015/06/15 Python
python中numpy包使用教程之数组和相关操作详解
2017/07/30 Python
Python reduce()函数的用法小结
2017/11/15 Python
Under Armour西班牙官网:美国知名的高端功能性运动品牌
2018/12/12 全球购物
瑞士图书网站:Weltbild.ch
2019/09/17 全球购物
社区春季防火方案
2014/06/02 职场文书
英语专业求职信
2014/07/08 职场文书
行政专员岗位职责范本
2014/08/26 职场文书
银行转正自我鉴定
2014/09/29 职场文书
2014年招商工作总结
2014/11/22 职场文书
一文教你快速生成MySQL数据库关系图
2022/06/28 Redis