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


Posted in HTML / CSS onMay 23, 2016

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 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 src="images/cardKingClub.png" alt="" width="142" height="200" />  
  12.         </div>  
  13.     </div>  
  14. </div>  

CSS

CSS Code复制内容到剪贴板
  1. .wrap {   
  2.     width500px;   
  3.     height300px;   
  4.     margin30px auto;   
  5.     positionrelative;   
  6.     backgroundurl(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.     width142px;   
  20.     height200px;   
  21.     positionabsolute;   
  22.     top: 50%;   
  23.     left: 50%;   
  24.     margin-left: -72px;   
  25.     margin-top: -101px;   
  26.     border1px dashed orange;   
  27.     cursorpointer;   
  28.     transform-style: preserve-3d;   
  29. }   
  30. /*调用动画*/  
  31. .spin:hover{   
  32.     animation:spin 5s linear infinite;   
  33. }   
  34. .rotate {   
  35.     backgroundurl(images/cardKingClub.png) no-repeat center;   
  36.     background-size: 100% 100%;   
  37.     border5px solid hsla(50,50%,50%,.9);   
  38.     transform: perspective(200px) rotateY(45deg);   
  39. }   
  40. .rotate img{   
  41.     border1px solid green;   
  42.     transform: rotateX(15deg) translateZ(10px);   
  43.     transform-origin: 0 0 40px;   
  44. }   
  45. /*改变transform-style的默认值*/  
  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属性详解

HTML / CSS 相关文章推荐
CSS3 Media Queries(响应式布局可以让你定制不同的分辨率和设备)
Jun 06 HTML / CSS
你应该知道的30个css选择器
Mar 19 HTML / CSS
用CSS3写的模仿iPhone中的返回按钮
Apr 04 HTML / CSS
CSS3 box-sizing属性详解
Nov 15 HTML / CSS
HTML5 语义化结构化规范化
Oct 17 HTML / CSS
html5指南-5.使用web storage存储键值对的数据
Jan 07 HTML / CSS
将HTML5 Canvas的内容保存为图片借助toDataURL实现
May 20 HTML / CSS
详解webapp页面滚动卡顿的解决办法
Dec 26 HTML / CSS
Canvas多边形绘制的实现方法
Aug 05 HTML / CSS
使用数据结构给女朋友写个Html5走迷宫游戏
Nov 26 HTML / CSS
HTML5实现直播间评论滚动效果的代码
May 27 HTML / CSS
血轮眼轮回眼特效 html+css
Mar 31 HTML / CSS
css 元素选择器的简单实例
May 23 #HTML / CSS
css sprite简单实例
May 23 #HTML / CSS
CSS3中的Transition过度与Animation动画属性使用要点
May 20 #HTML / CSS
CSS3制作炫酷的下拉菜单及弹起式选单的实例分享
May 17 #HTML / CSS
CSS3中各种颜色属性的使用教程
May 17 #HTML / CSS
使用CSS3美化HTML表单的技巧演示
May 17 #HTML / CSS
利用CSS3的border-radius绘制太极及爱心图案示例
May 17 #HTML / CSS
You might like
PHP+MYSQL开发工具及资源收藏
2007/01/02 PHP
解析strtr函数的效率问题
2013/06/26 PHP
PHP遍历并打印指定目录下所有文件实例
2014/02/10 PHP
为调试JavaScript添加输出窗口的代码
2010/02/07 Javascript
javascript 隐藏/显示指定的区域附HTML元素【legend】用法
2010/03/05 Javascript
date.parse在IE和FF中的区别
2010/07/29 Javascript
jQuery下的动画处理总结
2013/10/10 Javascript
深入探究JavaScript中for循环的效率问题及相关优化
2016/03/13 Javascript
jQuery实现简单的滑动导航代码(移动端)
2017/05/22 jQuery
jQuery实现 RadioButton做必选校验功能
2017/06/15 jQuery
通过V8源码看一个关于JS数组排序的诡异问题
2017/08/14 Javascript
angularjs实现简单的购物车功能
2017/09/21 Javascript
node通过express搭建自己的服务器
2017/09/30 Javascript
angularjs http与后台交互的实现示例
2018/12/21 Javascript
JavaScript实现左右滚动电影画布
2020/02/06 Javascript
[01:46]辉夜杯—打造中国DOTA新格局
2015/12/25 DOTA
[54:41]2018DOTA2亚洲邀请赛3月30日 小组赛B组 VGJ.T VS paiN
2018/03/31 DOTA
利用Python查看目录中的文件示例详解
2017/08/28 Python
解决python opencv无法显示图片的问题
2018/10/28 Python
python字符串和常用数据结构知识总结
2019/05/21 Python
django表单的Widgets使用详解
2019/07/22 Python
Python3 使用pillow库生成随机验证码
2019/08/26 Python
Python tkinter实现图片标注功能(完整代码)
2019/12/08 Python
Python读取分割压缩TXT文本文件实例
2020/02/14 Python
益模软件Java笔试题
2012/03/27 面试题
海量信息软件测试笔试题
2015/08/08 面试题
销售演讲稿范文
2014/01/08 职场文书
益达广告词
2014/03/14 职场文书
争先创优演讲稿
2014/09/15 职场文书
终止或解除劳动合同及劳动关系的证明书
2014/10/06 职场文书
2014年中学生检讨书大全
2014/10/09 职场文书
建筑工程催款函
2015/06/24 职场文书
2019西餐厅创业计划书范文!
2019/07/12 职场文书
致创业的您:这类人不适合餐饮创业
2019/08/19 职场文书
Win11应用商店打开闪退怎么解决? win11应用商店打不开的多种解决办法
2022/04/05 数码科技
Golang数据类型和相互转换
2022/04/12 Golang