首页 前端知识 使用CSS3实现酷炫的3D旋转视图,附超全教程文档

使用CSS3实现酷炫的3D旋转视图,附超全教程文档

2024-05-27 10:05:49 前端知识 前端哥 983 124 我要收藏

}

3D缩放
  • scaleX(x) 给定一个 X 轴的3D 缩放转换值

  • scaleY(x) 给定一个 Y 轴的3D 缩放转换值

  • scaleZ(x) 给定一个 Z 轴的3D 缩放转换值 缩放设置和上面的类似,这里就不做过多介绍了。

理论上说以上三种常见变换已经够用了,值得关注的是我们要想让元素呈现出3D效果,以下不可忽视的API也很重要:

2.CSS3 3D 应用场景

css 3D主要应用在网站的交互和模型效果上,比如:

  • 3D轮播图

  • 3D产品介绍

  • 室内3D仿真

  • h5 3D活动页面,比较典型的就是某年淘宝的年终总结H5

  • 3D数据可视化成图

  • 3D模型图 其实如果css 3D用的熟悉了,一些基本的3D模型完全可以用css画出来。

3.CSS3 3D 实现一个立方体

核心思路就是用6个面去拼接,通过设置rotate和translate来调整相互之间的位置,如下:

具体代码如下:

.container {

position: relative;

width: 300px;

height: 300px;

margin: 120px auto;

transform-style: preserve-3d;

/* 为了让其更有立体效果 */

transform: rotateX(-30deg) rotateY(45deg);

transform-origin: 150px 150px 150px;

animation: rotate 6s infinite;

}

.container .page {

position: absolute;

width: 300px;

height: 300px;

text-align: center;

line-height: 300px;

color: #fff;

background-size: cover;

}

.container .page:first-child {

background-image: url(./my.jpeg);

background-color: rgba(0,0,0,.2);

}

.container .page:nth-child(2) {

transform: rotateX(90deg);

transform-origin: 0 0;

transition: transform 10s;

background-color: rgba(179, 15, 64, 0.6);

background-image: url(./my2.jpeg);

}

.container .page:nth-child(3) {

transform: translateZ(300px);

background-color: rgba(22, 160, 137, 0.7);

background-image: url(./my3.jpeg);

}

.container .page:nth-child(4) {

transform: rotateX(-90deg);

transform-origin: -300px 300px;

background-color: rgba(210, 212, 56, 0.2);

background-image: url(./my4.jpeg);

}

.container .page:nth-child(5) {

transform: rotateY(-90deg);

transform-origin: 0 0;

background-color: rgba(201, 23, 23, 0.6);

background-image: url(./my5.jpeg);

}

.container .page:nth-child(6) {

transform: rotateY(-90deg) translateZ(-300px);

transform-origin: 0 300px;

background-color: rgba(16, 149, 182, 0.2);

background-image: url(./my6.jpeg);

}

html结构

A B C D E F

扩展

我们可以基于上面介绍的,给父元素添加动画或者拖拽效果,这样就可以做成更有交互性的3D方块了,比如置骰子游戏vr场景3D相册等等,具体实现我会抽空依次总结出来,记得关注哦~

点个『在看』支持下 

自我介绍一下,小编13年上海交大毕业,曾经在小公司待过,也去过华为、OPPO等大厂,18年进入阿里一直到现在。

深知大多数前端工程师,想要提升技能,往往是自己摸索成长或者是报班学习,但对于培训机构动则几千的学费,着实压力不小。自己不成体系的自学效果低效又漫长,而且极易碰到天花板技术停滞不前!

因此收集整理了一份《2024年Web前端开发全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友,同时减轻大家的负担。
img
img
img
img
img
img

既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上前端开发知识点,真正体系化!

由于文件比较大,这里只是将部分目录大纲截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且后续会持续更新

如果你觉得这些内容对你有帮助,可以添加V获取:vip1024c (备注前端)
img

最后

给大家分享一些关于HTML的面试题。


一个人可以走的很快,但一群人才能走的更远。不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎扫码加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!
img

最后

给大家分享一些关于HTML的面试题。

[外链图片转存中…(img-jaxlneUf-1712809184460)]
[外链图片转存中…(img-OIn09g8G-1712809184460)]

一个人可以走的很快,但一群人才能走的更远。不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎扫码加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!
[外链图片转存中…(img-HcU4o1Cw-1712809184460)]

转载请注明出处或者链接地址:https://www.qianduange.cn//article/9682.html
标签
评论
发布的文章

JQuery中的load()、$

2024-05-10 08:05:15

大家推荐的文章
会员中心 联系我 留言建议 回顶部
复制成功!