头闻号

义乌市美时化妆品有限公司

眼影|粉底|睫毛膏|眉笔|眼线笔、眼线液|美容材料及用具

首页 > 新闻中心 > 科技常识:CSS3中设置3D变形的transform
科技常识:CSS3中设置3D变形的transform
发布时间:2024-11-17 15:28:46        浏览次数:2        返回列表

今天小编跟大家讲解下有关CSS3中设置3D变形的transform-style属性详解 ,相信小伙伴们对这个话题应该有所关注吧,小编也收集到了有关CSS3中设置3D变形的transform-style属性详解 的相关资料,希望小伙伴们看了有所帮助。

transform-style属性是3D空间一个重要属性,指定嵌套元素如何在3D空间中呈现。他主要有两个属性值:flat和preserve-3d。

transform-style属性的使用语法非常简单:

CSS Code复制内容到剪贴板 transform-style:flat|preserve-3d

其中flat值为默认值,表示所有子元素在2D平面呈现。preserve-3d表示所有子元素在3D空间中呈现。

也就是说,如果对一个元素设置了transform-style的值为flat,则该元素的所有子元素都将被平展到该元素的2D平面中进行呈现。沿着X轴或Y轴方向旋转该元素将导致位于正或负Z轴位置的子元素显示在该元素的平面上,而不是它的前面或者后面。如果对一个元素设置了transform-style的值为preserve-3d,它表示不执行平展操作,他的所有子元素位于3D空间中。

transform-style属性需要设置在父元素中,并且高于任何嵌套的变形元素。最后,我们运用一个翻转的例子,来加深一下对transform-style属性的印象:HTML模板

XML/HTML Code复制内容到剪贴板 <divclass="wrap"> <divclass="spin"> <divclass="rotate"> <imgsrc=http://xyrl.com/skin/7ke/image/nopic.gif </div> </div> </div> <divclass="wrap"> <divclass="spin"> <divclass="rotatethree-d"> <imgsrc=http://xyrl.com/skin/7ke/image/nopic.gif </div> </div> </div>

CSS

CSS Code复制内容到剪贴板 .wrap{ width:500px; height:300px; margin:30pxauto; position:relative; background:url(images/bg-grid.jpg)no-repeatcentercenter; background-size:100%100%; } @keyframesspin{ 0%{ transform:rotateY(0deg) } 100%{ transform:rotateY(360deg) } } .spin{ width:142px; height:200px; position:absolute; top:50%; left:50%; margin-left:-72px; margin-top:-101px; border:1pxdashedorange; cursor:pointer; transform-style:preserve-3d; } .spin:hover{ animation:spin5slinearinfinite; } .rotate{ background:url(images/cardKingClub.png)no-repeatcenter; background-size:100%100%; border:5pxsolidhsla(50,50%,50%,.9); transform:perspective(200px)rotateY(45deg); } .rotateimg{ border:1pxsolidgreen; transform:rotateX(15deg)translateZ(10px); transform-origin:0040px; } .three-d{ transform-style:preserve-3d; }

特别声明:为了节省篇幅,代码中CSS3属性代码省去了各浏览器的私有前缀,在实际操作中,需要将各浏览器前缀加上,才会有效果。

其效果如下所示:

正如您所看到的,当元素设置.rotate设置了flat值时,其子元素img不会根据translateZ()值摊开,而在同一平面旋转,如上图上部分所示;当元素.rotate设置了preserve-3d值时,其子元素img会根据translateZ()值摊开,不再会堆叠在一起,如上图下部分所示。

有一点需要特别提醒大家,如果你的元素设置了transform-style值为preserve-3d,就不能为了防止子元素溢出容器而设置overflow值为hidden,如果设置了overflow:hidden同样可以迫死子元素出现在同一平面(和元素设置了transform-style为flat一样的效果),如下图所示:

来源:爱蒂网