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实现炫酷的飞机起飞动画
Sep 17 HTML / CSS
CSS3 box-sizing属性
Apr 17 HTML / CSS
CSS3实现的闪烁跳跃进度条示例(附源码)
Aug 19 HTML / CSS
深入浅析CSS3中的Flex布局整理
Apr 27 HTML / CSS
CSS3中引入多种自定义字体font-face
Jun 12 HTML / CSS
解决H5的a标签的download属性下载service上的文件出现跨域问题
Jul 16 HTML / CSS
html5实现完美兼容各大浏览器的播放器
Dec 26 HTML / CSS
html5 postMessage前端跨域并前端监听的方法示例
Nov 01 HTML / CSS
html svg生成环形进度条的实现方法
Sep 23 HTML / CSS
Html5+CSS3+EL表达式问题小结
Dec 19 HTML / CSS
使用canvas仿Echarts实现金字塔图的实例代码
Nov 11 HTML / CSS
聊聊CSS粘性定位sticky案例解析
Jun 01 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
php按字符无乱码截取中文的方法
2015/03/27 PHP
thinkphp微信开之安全模式消息加密解密不成功的解决办法
2015/12/02 PHP
PHP获取客户端及服务器端IP的封装类
2016/07/21 PHP
PHP基于array_unique实现二维数组去重
2020/07/14 PHP
js中匿名函数的N种写法
2010/09/08 Javascript
createElement与createDocumentFragment的点点区别小结
2011/12/19 Javascript
在js文件中如何获取basePath处理js路径问题
2013/07/10 Javascript
使用JavaScript和C#中获得referer
2014/11/14 Javascript
使用jquery实现仿百度自动补全特效
2015/07/23 Javascript
Bootstrap实现默认导航栏效果
2020/09/21 Javascript
AngularJS使用ng-Cloak阻止初始化闪烁问题的方法
2016/11/03 Javascript
JS查找数组中重复元素的方法详解
2017/06/14 Javascript
使用js在layui中实现上传图片压缩
2019/06/18 Javascript
使用layer.msg 时间设置不起作用的解决方法
2019/09/12 Javascript
vue解决使用$http获取数据时报错的问题
2019/10/30 Javascript
微信小程序多列表渲染数据开关互不影响的实现
2020/06/05 Javascript
python用ConfigObj读写配置文件的实现代码
2013/03/04 Python
Python程序设计入门(4)模块和包
2014/06/16 Python
Python实现二叉堆
2016/02/03 Python
pytorch 更改预训练模型网络结构的方法
2019/08/19 Python
Python列表删除元素del、pop()和remove()的区别小结
2019/09/11 Python
windows10环境下用anaconda和VScode配置的图文教程
2020/03/30 Python
哈工大自然语言处理工具箱之ltp在windows10下的安装使用教程
2020/05/07 Python
Python turtle库的画笔控制说明
2020/06/28 Python
DeinDesign德国:设计自己的手机壳
2019/12/14 全球购物
创立科技Java面试题
2015/11/29 面试题
经贸日语毕业生自荐信
2013/11/03 职场文书
syb养殖创业计划书
2014/01/09 职场文书
2014年大学庆元旦迎新年活动方案
2014/03/09 职场文书
文体活动实施方案
2014/03/27 职场文书
群众路线自我剖析及整改措施
2014/11/04 职场文书
年中了,该如何写好个人述职报告?
2019/07/02 职场文书
2019年市场部个人述职报告(三篇)
2019/10/23 职场文书
python基于tkinter制作m3u8视频下载工具
2021/04/24 Python
MySQL面试题讲解之如何设置Hash索引
2021/11/01 MySQL
vue数据字典取键值项目的字典问题
2022/04/12 Vue.js