CSS3中的transform属性进行2D和3D变换的基本用法

作者:互联网

2026-03-30

HTML教程

transform 2D之前有看到google将搜寻的页面倾斜,这个功能透过CSS3的transform就可以达成CSS3 2D transform特性可以旋转、倾斜、放大缩小和移动元素,对网页的视觉观感上提供很大的帮助使用方法:

CSS Code复制内容到剪贴板
  1. transform:transform-function;
  2. -webkit-transform:transform-function;/*SafariandChrome*/
  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. /*SafariandChrome网页倾斜50度*/
  2. -webkit-transform:rotate(50deg);

transform 3D & perspectiveCSS3的transform可以做2D的操作,当然也有3D但需要再一个拥有perspective属性的父元素才能显现3D的效果例如:

XML/HTML Code复制内容到剪贴板
  1. <divid="div1">
  2. <divid="div2">3Ddiv>
  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%;/*SafariandChrome*/
  3. -webkit-perspective-origin:40px60px;/*SafariandChrome*/
  4. -moz-perspective-origin:leftbottombottom;/*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);