TONG-H

(译)CSS 是魔法, 是时候试试 3D 了

1.5k5WEBtranslation2021-07-282025-01-02

CSS 是魔法, 是时候试试 3D 了

小狗插图:[subpng](https://www.subpng.com/),眼睛插图:[pngegg](https://www.pngegg.com)

CSS transform 是 css 最全能,最神奇的属性之一。它不仅是在你的网站上实现平滑动画的最佳方式,更是你创造奇迹的一种方式。比如这个 🙀 —

CSS 3D 立方体!

我先为这几个占了你的网络宽带的动图道歉,但我希望它是值得的!🤜🤛

等下,这个立方体的两个面不见了!!!

我是故意这么做的,这样就会更形象,也更容易理解。我会在文章末尾添加一个链接用于获取上面示例的完整代码!

先说最重要的,Translate 是如何工作的?

translate 方法主要是将一个 html 元素从它真实的位置上移动,而且不会干扰布局树上的其他兄弟或父级元素。简单来说,translateX 方法是将元素左右移动,而 translateY 是上下移动元素。

translate 是如何使元素在 X 轴和 Y 轴中平移的

但 Z 轴是什么?

为了更形象地了解 translate 是如何沿着 Z 轴工作的,想象一下你的 div 在你的屏幕中前后移动而不是上下或左右。

沿着 Z 轴平移

这怎么可能?一个网站看上去就像是一本书中的一页纸,对吧?怎么可能会有东西从屏幕中跑出来向你靠近(或者远离你)?

你的 div 当然不会真的跑出来,但它给你一种感觉好像它会。让我们一起看看沿着不同的轴修改 translate 的值会怎样。

我不知道你怎么想,但这个绿色的盒子看起来并不像是在靠近或者远离我。👺

如何解决这个问题呢?我们需要改变一下我们的视角。😉

CSS 的 perspective 属性

如果不设置正确的 perspective 值,你无法在视觉上检测到 Z 轴的改变。

perspective 属性定义元素与用户的距离。那么,相比于一个较高的值,一个较低的值产生的 3D 效果会更强烈。

来源 —— W3 Schools

让我们给这三个方块的父元素加上下面的 CSS ——

瞧:

rotate 方法

顾名思义,rotate 根据一个给定的角度,沿着某一个轴旋转元素。但我们需要一点视觉效果来展示 rotate 是如何沿着不同的轴工作的。

在没有 perspective 的情况下沿着不同的轴旋转

有 perspective 的情况下沿着不同的轴旋转

立方体

我们终于可以从立方体的面开始了!我们将有四个面 —— bottom,front,back,left:

同样的,我为主要的包裹容器 box-wrapper 添加了一些 css。

注意我为容器添加了 transform-style: preserve-3d,这是渲染 3D 子元素的一个重要步骤。每一个面的宽高都是 200px,我们需要记住这个值,因为我们将依据每一个面的尺寸为每个面添加 translate 值。

立方体的每一个面都将是一个绝对的划分,我添加了文字用于代表每一个面。我为每一个面添加了 opacity: 0.5,这样就能清楚地看到它们之间的重叠了。

为了将 front 放到前面,我们为它添加 translateZ(100px)

对,看起来就像这样。🙁

那么我们怎么使它 3D ?我们的 perspective 知识在这里要派上用场了。

添加这个 css 到包裹容器的父级元素 box-container

同样的,为了将 back 调后,我们将为它添加与 front 相反的 css。

效果 ——

你能够想象 front 向你靠近,back (黄色那个)离你远去吗?如果这仍然不足以描绘,那让我们试着把立方体的包裹容器旋转一下:

很奇妙,对吗?

下一步,我们需要安顿 bottom 💁‍♀️,为了将 bottom 放到适当的位置,我们把他沿着 X 轴旋转 ** 90 度**。

我们还需要移动它的位置使它能正好在立方体的 front 和 back 之间。我们可以做的是移动 bottom 使其与 front 一致,然后旋转它。听起来有点困惑对吗?

步骤 —— 1: 将 bottom 和 front 对齐

CSS:

将 bottom 和 front 对齐

效果:

将 bottom 和 front 对齐

步骤 —— 2: 将 bottom 旋转 90 度

CSS:

将 bottom 的 translate 和 rotate 相结合

Result:

将 bottom 的 translate 和 rotate 相结合

bottom 看起来现在安全的在自己的位置上了。但 left 好像被困在了中间。🙍‍♀️ 首先我们需要将它移动到旁边然后旋转它。让我们把他沿着 X 轴移动 -100px,然后在 Y 轴上旋转它。

CSS:

效果:

!我们的近似立方体已经快完成了。我建议你在每一个轴上都尝试调整一下 translate 和 rotate 的值,尝试添加顶面和右面去做一个完整的立方体。

现在,最后关键的一步,旋转我们的立方体 😍

CSS:

将上面的动画添加到我们的 box-wrapper 上 ——

效果 🤜🤛:

相同的工作代码,参考[GitHub 仓库]](https://github.com/ankita1010/css-cube),尝试体验一下 CSS 3D 这个魔法之池。💫

请注意 —— 我调整了 perspective 的值,以及添加了一些动画来达到侧面的最终位置,以更清楚地展示变化。我稍微旋转了 box-wrapper,这样从正确的角度看更明显些。

干杯!

如果发现译文存在错误或其他需要改进的地方,欢迎到 掘金翻译计划 对译文进行修改并 PR,也可获得相应奖励积分。文章开头的 本文永久链接 即为本文在 GitHub 上的 MarkDown 链接。


掘金翻译计划 是一个翻译优质互联网技术文章的社区,文章来源为 掘金 上的英文分享文章。内容覆盖 AndroidiOS前端后端区块链产品设计人工智能等领域,想要查看更多优质译文请持续关注 掘金翻译计划官方微博知乎专栏