小编给大家分享一下使用纯CSS如何实现3D旋转效果,希望大家阅读完这篇文章之后都有所收获,下面让我们一起去探讨吧!
主要使用CSS中的 preserve-3d 、perspective 属性实现3D效果
效果
HTML代码
<body> <div class="box"> <div class="face front"> <h3>前面</h3> </div> <div class="face back"> <h3>背面</h3> </div> </div> </body>
为了演示效果,将元素居中,body的css设置
*{ margin: 0; padding: 0; } body{ width: 100%; height: 100vh; display: flex; justify-content: center; align-items: center; background: #333; }
box 属性设置
.box{ width: 300px; height: 400px; transform-style: preserve-3d; position: relative; } .face{ position: absolute; left: 0; top: 0; width: 100%; height: 100%; transform-style: preserve-3d; display: flex; justify-content: center; align-items: center; backface-visibility: hidden; transition: 2s ease-in-out; transform: perspective(500px) rotateY(0deg); }
前面属性设置
.face.front{ background: #ff0; }
背面属性设置,在Y轴旋转 180度,先不显示
.face.back{ background: #3bc2ff; color: #fff; transform: perspective(500px) rotateY(180deg); }
设置悬浮的动画效果
.box:hover .face.front{ transform: perspective(500px) rotateY(180deg); } .box:hover .face.back{ transform: perspective(500px) rotateY(360deg); }
设置文字的悬浮效果
.box .face h3{ font-size: 4em; text-transform: uppercase; transform: perspective(500px) translateZ(50px); }
看完了这篇文章,相信你对“使用纯CSS如何实现3D旋转效果”有了一定的了解,如果想了解更多相关知识,欢迎关注亿速云行业资讯频道,感谢各位的阅读!
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。