CSS3中设置3D变形的transform-style属性详解

时间:2021-05-08

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="images/cardKingClub.png"alt=""width="142"height="200"/>
  • </div>
  • </div>
  • </div>
  • <divclass="wrap">
  • <divclass="spin">
  • <divclass="rotatethree-d">
  • <imgsrc="images/cardKingClub.png"alt=""width="142"height="200"/>
  • </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一样的效果),如下图所示:

    声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。

    相关文章