一,转换(transform)是CSS3中具有颠覆性的特征之一,可以实现元素的位移,旋转,缩放等效果。分为两种转换,分别是2D以及3D转换效果。

转换可以简单理解为的变形,其主要效果有三种:

  • 移动:translate;
  • 旋转:rotate;
  • 缩放:scale;  

1,2D转换前置知识:

了解二维坐标系

x轴水平向右,y轴垂直向下。

2,2D转换的几种变换方法:

  • translate()   位移
  • rotate()   旋转
  • scale()   缩放

     translate()位移方法  ,有两个参数(x轴平移距离,y轴平移距离),从当前元素位置移动。

位移:transform:translate(水平移动距离,垂直移动距离 ) 中间用逗号隔开

取值:数字px /百分比(基于盒子自身的百分比)

技巧:如果只给一个值,表示x轴方向移动

想单独给某个方向移动:translate X() / translate Y()

特点:会增大盒子层级,没有脱标,对行内元素不起效果

使用方法:

div{
width:100px;
height:100px;
background-color: aqua;
transform: translate(50px,60px);
}

水平方向移动50px,垂直方向移动60px。效果如图所示:(图中为方便看出效果,所以使用两种颜色作为前后对比,以下都是)。当值为负数时,就是沿着该方向的反方向移动。

rotate()旋转方法给定度数顺时针旋转的元素。允许负值,这样是元素逆时针旋转

旋转:transform:rotate(角度)注意:单位是deg,一圈是360deg

取值:单位是deg,正负均可

div{
  width:100px;
  height:100px;
  background-color: aqua;
  transform: rotate(30deg);
}

前后效果对比:
   

 scale()元素宽高增加或减少的大小,类如transform: scale(1,2)宽不变,高放大两倍。

数字大于1表示放大,小于1表示缩小,小于1表示不变,只写一个值,表示x轴和y轴等比例缩放

div{
transform: scale(1,2);
}

 

 

二,空间转换(3D转换)

定义:由x,y,z轴组成立体空间,z轴与视线方向相同(正值指向用户本身)

位移:transform:translate3d(x,y,z),因为是空间转换,后面需要填写3d,单独写需要把三个坐标轴单独写

透视效果:perspective :值(取值一般400-1200px),属性加给父级

z轴是视线方向,产生近大远小

空间旋转

transform:rotateZ(值deg )

带了什么值表示沿着哪个值执行指令

transform:rotateX(值deg ),加上透视属性,像手心一样

transform:rotateY(值deg ),像开门一样

立体呈现:transform-style:preseve-3d

给父元素添加属性,按需求设置盒子的位置(位移或旋转),用子绝父相定位,在选择一个盒子往前拉(transform:translate),

作用:使子元素处于真正的3d空间

 

Logo

华为开发者空间,是为全球开发者打造的专属开发空间,汇聚了华为优质开发资源及工具,致力于让每一位开发者拥有一台云主机,基于华为根生态开发、创新。

更多推荐