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 相关文章推荐
网页切图的CSS和布局经验与要点
Apr 09 HTML / CSS
详解CSS中iconfont的使用
Aug 04 HTML / CSS
深入浅析css3 border-image边框图像详解
Nov 24 HTML / CSS
css3 利用transform打造走动的2D时钟
Oct 20 HTML / CSS
HTML5印章绘制电子签章图片(中文英文椭圆章、中文英文椭圆印章)
Jun 03 HTML / CSS
HTML5注册表单的自动聚焦与占位文本示例代码
Jul 19 HTML / CSS
简单介绍HTML5中的文件导入
May 08 HTML / CSS
canvas学习总结三之绘制路径-线段
Jan 31 HTML / CSS
如何给HTML标签中的文本设置修饰线
Nov 18 HTML / CSS
前端H5 Video常见使用场景简介
Aug 21 HTML / CSS
如何解决flex文本溢出问题小结
Jul 15 HTML / CSS
table不让td文字溢出操作方法
Dec 24 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面向对象全攻略 (四)构造方法与析构方法
2009/09/30 PHP
PHP函数学习之PHP函数点评
2012/07/05 PHP
在项目中寻找代码的坏命名
2012/07/14 PHP
div li的多行多列 无刷新分页示例代码
2013/10/16 PHP
laravel 解决Validator使用中出现的问题
2019/10/25 PHP
用Javscript实现表单复选框的全选功能
2007/05/25 Javascript
JavaScript Object的extend是一个常用的功能
2009/12/02 Javascript
jQuery EasyUI API 中文文档 - Tabs标签页/选项卡
2011/10/01 Javascript
从数据结构的角度分析 for each in 比 for in 快的多
2013/07/07 Javascript
js利用数组length属性清空和截短数组的小例子
2014/01/15 Javascript
邮箱下拉自动填充选择示例代码附图
2014/04/03 Javascript
jQuery simpleModal插件的使用介绍
2016/08/30 Javascript
async/await与promise(nodejs中的异步操作问题)
2017/03/03 NodeJs
浅谈Node异步编程的机制
2017/10/18 Javascript
详解Vue + Vuex 如何使用 vm.$nextTick
2017/11/20 Javascript
浅谈Vue数据响应思路之数组
2018/11/06 Javascript
node.js使用fs读取文件出错的解决方案
2019/10/23 Javascript
微信小程序复选框实现多选一功能过程解析
2020/02/14 Javascript
文章或博客自动生成章节目录索引(支持三级)的实现代码
2020/05/10 Javascript
0基础学习前端开发的一些建议
2020/07/14 Javascript
解决父组件将子组件作为弹窗调用只执行一次created的问题
2020/07/24 Javascript
Openlayers实现扩散的动态点(水纹效果)
2020/08/17 Javascript
Python检测生僻字的实现方法
2016/10/23 Python
python实现排序算法解析
2018/09/08 Python
python实现矩阵打印
2019/03/02 Python
基于python分析你的上网行为 看看你平时上网都在干嘛
2019/08/13 Python
基于python cut和qcut的用法及区别详解
2019/11/22 Python
python实现局域网内实时通信代码
2019/12/22 Python
Python+opencv+pyaudio实现带声音屏幕录制
2019/12/23 Python
会计专业职业规划:规划自我赢取未来
2014/02/12 职场文书
消防志愿者活动方案
2014/08/23 职场文书
就业协议书怎么填
2014/09/15 职场文书
小学中等生评语
2014/12/29 职场文书
求职导师推荐信范文
2015/03/27 职场文书
同意离婚答辩状
2015/05/22 职场文书
GoFrame基于性能测试得知grpool使用场景
2022/06/21 Golang