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代码绘制可爱的Hello Kitty猫
Aug 03 HTML / CSS
浅析css3中matrix函数的使用
Jun 06 HTML / CSS
CSS3的颜色渐变效果的示例代码
Sep 29 HTML / CSS
CSS3实现彩色进度条动画的示例
Oct 29 HTML / CSS
html5新特性与用法大全
Sep 13 HTML / CSS
会走动的图形html5时钟示例
Apr 27 HTML / CSS
html5小技巧之通过document.head获取head元素
Jun 04 HTML / CSS
利用纯html5绘制出来的一款非常漂亮的时钟
Jan 04 HTML / CSS
3种方式实现瀑布流布局小结
Sep 05 HTML / CSS
iframe跨域的几种常用方法
Nov 11 HTML / CSS
Html5踩坑记之mandMobile使用小记
Apr 02 HTML / CSS
新的CSS 伪类函数 :is() 和 :where()示例详解
Aug 05 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的博客ping服务代码
2012/02/04 PHP
PHP中数据类型转换的三种方式
2015/04/02 PHP
为你总结一些php信息函数
2015/10/21 PHP
一款JavaScript压缩工具:X2JSCompactor
2007/06/13 Javascript
JavaScript 利用StringBuffer类提升+=拼接字符串效率
2009/11/24 Javascript
js取得url地址参数实例
2013/02/22 Javascript
javascript跟随滚动效果插件代码(javascript Follow Plugin)
2013/08/03 Javascript
JS页面延迟执行一些方法(整理)
2013/11/11 Javascript
JS限制文本框只能输入数字和字母方法
2015/02/28 Javascript
Windows系统下使用Sublime搭建nodejs环境
2015/04/13 NodeJs
javascript cookie的简单应用
2016/02/24 Javascript
JS代码防止SQL注入的方法(超简单)
2016/04/12 Javascript
深入理解bootstrap框架之第二章整体架构
2016/10/09 Javascript
JavaScript-定时器0~9抽奖系统详解(代码)
2017/08/16 Javascript
jQuery实现动态添加节点与遍历节点功能示例
2017/11/09 jQuery
基于JavaScript中字符串的match与replace方法(详解)
2017/12/04 Javascript
LayUI表格批量删除方法
2018/08/15 Javascript
python网络编程学习笔记(10):webpy框架
2014/06/09 Python
python处理文本文件并生成指定格式的文件
2014/07/31 Python
python3中的md5加密实例
2018/05/29 Python
python实现括号匹配的思路详解
2018/08/23 Python
Python之列表实现栈的工作功能
2019/01/28 Python
python lxml中etree的简单应用
2019/05/10 Python
python输出决策树图形的例子
2019/08/09 Python
通过实例解析python subprocess模块原理及用法
2020/10/10 Python
flask项目集成swagger的方法
2020/12/09 Python
Windows和Linux动态库应用异同
2016/04/17 面试题
我爱祖国演讲稿
2014/09/02 职场文书
2014年学生会工作总结
2014/11/07 职场文书
2014大学生学生会工作总结
2014/12/19 职场文书
学生保证书
2015/01/16 职场文书
个人年终总结结尾
2015/03/06 职场文书
幼儿园小朋友毕业感言
2015/07/30 职场文书
详解Redis复制原理
2021/06/04 Redis
iSCSI服务器CHAP双向认证配置
2022/04/01 Servers
python中 .npy文件的读写操作实例
2022/04/14 Python