我的编程空间,编程开发者的网络收藏夹
学习永远不晚

CSS3中设置3D变形的transform-style属性介绍

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

CSS3中设置3D变形的transform-style属性介绍

这篇文章主要介绍“CSS3中设置3D变形的transform-style属性介绍”,在日常操作中,相信很多人在CSS3中设置3D变形的transform-style属性介绍问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”CSS3中设置3D变形的transform-style属性介绍”的疑惑有所帮助!接下来,请跟着小编一起来学习吧!

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

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

CSS Code复制内容到剪贴板

  1. 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复制内容到剪贴板

  1. <div class="wrap">  

  2.     <div class="spin">  

  3.         <div class="rotate">  

  4.             <img class="lazy" data-src="images/cardKingClub.png" alt="" width="142" height="200" />  

  5.         </div>  

  6.     </div>  

  7. </div>  

  8. <div class="wrap">  

  9.     <div class="spin">  

  10.         <div class="rotate three-d">  

  11.             <img class="lazy" data-src="images/cardKingClub.png" alt="" width="142" height="200" />  

  12.         </div>  

  13.     </div>  

  14. </div>  

CSS

CSS Code复制内容到剪贴板

  1. .wrap {   

  2.     width: 500px;   

  3.     height: 300px;   

  4.     margin: 30px auto;   

  5.     position: relative;   

  6.     background: url(images/bg-grid.jpg) no-repeat center center;   

  7.     background-size: 100% 100%;   

  8. }   

  9.   

  10. @keyframes spin{   

  11.     0%{   

  12.         transform:rotateY(0deg)   

  13.     }   

  14.     100%{   

  15.         transform:rotateY(360deg)   

  16.     }   

  17. }   

  18. .spin {   

  19.     width: 142px;   

  20.     height: 200px;   

  21.     position: absolute;   

  22.     top: 50%;   

  23.     left: 50%;   

  24.     margin-left: -72px;   

  25.     margin-top: -101px;   

  26.     border: 1px dashed orange;   

  27.     cursor: pointer;   

  28.     transform-style: preserve-3d;   

  29. }   

  30.   

  31. .spin:hover{   

  32.     animation:spin 5s linear infinite;   

  33. }   

  34. .rotate {   

  35.     background: url(images/cardKingClub.png) no-repeat center;   

  36.     background-size: 100% 100%;   

  37.     border: 5px solid hsla(50,50%,50%,.9);   

  38.     transform: perspective(200px) rotateY(45deg);   

  39. }   

  40. .rotate img{   

  41.     border: 1px solid green;   

  42.     transform: rotateX(15deg) translateZ(10px);   

  43.     transform-origin: 0 0 40px;   

  44. }   

  45.   

  46. .three-d {   

  47.     transform-style: preserve-3d;   

  48. }  

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

其效果如下所示:
CSS3中设置3D变形的transform-style属性介绍

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

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

到此,关于“CSS3中设置3D变形的transform-style属性介绍”的学习就结束了,希望能够解决大家的疑惑。理论与实践的搭配能更好的帮助大家学习,快去试试吧!若想继续学习更多相关知识,请继续关注编程网网站,小编会继续努力为大家带来更多实用的文章!

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

CSS3中设置3D变形的transform-style属性介绍

下载Word文档到电脑,方便收藏和打印~

下载Word文档

编程热搜

目录