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 相关文章推荐
让IE6支持css3,让 IE7、IE8 都支持CSS3
Oct 09 HTML / CSS
css3高级选择器使用方法
Dec 02 HTML / CSS
浅析css3中matrix函数的使用
Jun 06 HTML / CSS
利用CSS3实现平移动画效果示例代码
Oct 12 HTML / CSS
Html5页面在微信端的分享的实现方法
Aug 30 HTML / CSS
HTML5之SVG 2D入门9—蒙板及mask元素介绍与应用
Jan 30 HTML / CSS
HTML5在canvas中绘制复杂形状附效果截图
Jun 23 HTML / CSS
HTML5中外部浏览器唤起微信分享
Jan 02 HTML / CSS
css3 利用transform-origin 实现圆点分布在大圆上布局及旋转特效
Apr 29 HTML / CSS
浅谈CSS不规则边框的生成方案
May 25 HTML / CSS
css 边框添加四个角的实现代码
Oct 16 HTML / CSS
CSS实现五种常用的2D转换
Dec 06 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 采集程序原理分析篇
2010/03/05 PHP
php HtmlReplace输入过滤安全函数
2010/07/03 PHP
php计算函数执行时间的方法
2015/03/20 PHP
Yii实现微信公众号场景二维码的方法实例
2020/08/30 PHP
javascript之对系统的toFixed()方法的修正
2007/05/08 Javascript
JavaScript面向对象之静态与非静态类
2010/02/03 Javascript
Three.js学习之几何形状
2016/08/01 Javascript
Bootstrap基本插件学习笔记之Popover提示框(19)
2016/12/08 Javascript
浅谈键盘上回车按钮的js触发事件
2017/02/13 Javascript
JavaScript实现一个简易的计算器实例代码
2018/05/10 Javascript
javascript显示动态时间的方法汇总
2018/07/06 Javascript
js中this的指向问题归纳总结
2018/11/28 Javascript
详解使用React制作一个模态框
2019/03/14 Javascript
JavaScript 监听组合按键思路及代码实现
2020/07/28 Javascript
解决在Vue中使用axios POST请求变成OPTIONS的问题
2020/08/14 Javascript
解决vue侦听器watch,调用this时出现undefined的问题
2020/10/30 Javascript
Python环境变量设置方法
2016/08/28 Python
Python基于Pymssql模块实现连接SQL Server数据库的方法详解
2017/07/20 Python
django 删除数据库表后重新同步的方法
2018/05/27 Python
解决Django migrate No changes detected 不能创建表的问题
2018/05/27 Python
python实现自动发送邮件
2018/06/20 Python
在Django下创建项目以及设置settings.py教程
2019/12/03 Python
python3将变量写入SQL语句的实现方式
2020/03/02 Python
python3.7中安装paddleocr及paddlepaddle包的多种方法
2020/11/27 Python
有关HTML5 Video对象的ontimeupdate事件(Chrome上无效)的问题
2013/07/19 HTML / CSS
Trunki英国官网:儿童坐骑式行李箱
2017/05/30 全球购物
幼儿园教师奖惩制度
2014/02/01 职场文书
施工材料员岗位职责
2014/02/12 职场文书
消防志愿者活动方案
2014/08/23 职场文书
报考公务员诚信承诺书
2014/08/29 职场文书
上课睡觉检讨书300字
2014/11/18 职场文书
个人年底工作总结
2015/03/10 职场文书
运输公司工作总结
2015/08/11 职场文书
九年级历史教学反思
2016/02/19 职场文书
Python pygame实现中国象棋单机版源码
2021/06/20 Python
Python+Tkinter制作专属图形化界面
2022/04/01 Python