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中动画属性transform、transition和animation属性的区别
Sep 25 HTML / CSS
CSS3属性选择符介绍
Oct 17 HTML / CSS
利用CSS3把图片变成灰色模式的实例代码
Sep 06 HTML / CSS
如何用css3实现switch组件开关的方法
Feb 09 HTML / CSS
纯CSS3+DIV实现小三角形边框效果的示例代码
Aug 03 HTML / CSS
CSS3 filter(滤镜)实现网页灰色或者黑色模式的代码
Nov 30 HTML / CSS
HTML5边玩边学(2)基础绘图实现方法
Sep 21 HTML / CSS
Bootstrap 学习分享
Nov 12 HTML / CSS
通过Canvas及File API缩放并上传图片完整示例
Aug 08 HTML / CSS
html5使用canvas画三角形
Dec 15 HTML / CSS
html5表单及新增的改良元素详解
Jun 07 HTML / CSS
AmazeUI导航的示例代码
Aug 14 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的call_user_func传reference引发的思考
2010/07/23 PHP
比较简单的百度网盘文件直链PHP代码
2013/03/24 PHP
PHP之APC缓存详细介绍 apc模块安装
2014/01/13 PHP
PHP解压tar.gz格式文件的方法
2016/02/14 PHP
浅析php中array_map和array_walk的使用对比
2016/11/20 PHP
php 访问oracle 存储过程实例详解
2017/01/08 PHP
laravel如何开启跨域功能示例详解
2017/08/31 PHP
js 代码集(学习js的朋友可以看下)
2009/07/22 Javascript
Javascript select下拉框操作常用方法
2009/11/09 Javascript
javascript中interval与setTimeOut的区别示例介绍
2014/03/14 Javascript
javascript数组遍历for与for in区别详解
2014/12/04 Javascript
基于jquery实现放大镜效果
2015/08/17 Javascript
js性能优化技巧
2015/11/29 Javascript
js运动应用实例解析
2015/12/28 Javascript
js随机生成26个大小写字母
2016/02/12 Javascript
js实现精确到秒的倒计时效果
2016/05/29 Javascript
Bootstrap表单控件使用方法详解
2017/01/11 Javascript
深入理解Commonjs规范及Node模块实现
2017/05/17 Javascript
详解如何构建Angular项目目录结构
2017/07/13 Javascript
原生js实现密码输入框值的显示隐藏
2017/07/17 Javascript
vue2.x+webpack快速搭建前端项目框架详解
2017/11/30 Javascript
vue全屏事件开发详解
2020/06/17 Javascript
vue实现列表滚动的过渡动画
2020/06/29 Javascript
js实现电灯开关效果
2021/01/19 Javascript
[01:03:36]Ti4 循环赛第三日DK vs Titan
2014/07/12 DOTA
Python 实现一个颜色色值转换的小工具
2016/12/06 Python
Python读取mat文件,并保存为pickle格式的方法
2018/10/23 Python
python 文件查找及内容匹配方法
2018/10/25 Python
简单了解python变量的作用域
2019/07/30 Python
如何利用python 读取配置文件
2021/01/06 Python
python 实现图片裁剪小工具
2021/02/02 Python
css3 transform属性详解
2014/09/30 HTML / CSS
英国女性时尚精品店:THE DRESSING ROOM
2018/05/23 全球购物
前台接待岗位职责范本
2015/04/03 职场文书
求职自荐信该如何书写?
2019/06/24 职场文书
mysql主从复制的实现步骤
2021/10/24 MySQL