HTML&CSS:3D加载动画的实现

这个页面实现了一个带有两组不同颜色和渐变效果的加载动画。每组动画包含四个加载器,每个加载器都有一个旋转动画和光点效果。页面使用了CSS动画和渐变背景来增强视觉效果,整体设计风格现代且具有视觉吸引力。


大家复制代码时,可能会因格式转换出现错乱,导致样式失效。建议先少量复制代码进行测试,若未能解决问题,私信回复源码两字,我会发送完整的压缩包给你。

演示效果

HTML&CSS

html 复制代码
<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>公众号关注:前端Hardy</title>
    <style>
        * {
            margin: 0;
            padding: 0;
            box-sizing: border-box;
        }

        @keyframes animate {
            0% {
                transform: rotate(0deg);
            }

            100% {
                transform: rotate(360deg);
            }
        }

        body {
            display: flex;
            justify-content: center;
            align-items: center;
            min-height: 100vh;
            background: #000;
        }

        .loader-container {
            position: relative;
            width: 100%;
            height: 200px;
            display: flex;
            align-items: center;
            justify-content: center;
            -webkit-box-reflect: below 0 linear-gradient(transparent, transparent, rgba(0, 0, 0, 0.333));
        }

        .loader {
            position: absolute;
            width: 200px;
            height: 200px;
            border-radius: 50%;
            animation: animate 2s linear infinite;
        }

        .loader1:before,
        .loader2:before {
            content: "";
            position: absolute;
            top: 0;
            left: 0;
            width: 50%;
            height: 100%;
            background: linear-gradient(to top, transparent, rgba(0, 255, 249, 0.4));
            background-size: 100px 180px;
            background-repeat: no-repeat;
            border-top-left-radius: 100px;
            border-bottom-left-radius: 100px;
        }

        .loader2,
        .loader4 {
            animation-delay: -1s;
            filter: hue-rotate(290deg);
        }

        .loader i {
            position: absolute;
            top: 0;
            left: 50%;
            transform: translateX(-50%);
            width: 20px;
            height: 20px;
            background: #00fff9;
            border-radius: 50%;
            z-index: 100;
            box-shadow: 0 0 10px #00fff9, 0 0 20px #00fff9, 0 0 30px #00fff9,
                0 0 40px #00fff9, 0 0 50px #00fff9, 0 0 60px #00fff9, 0 0 70px #00fff9,
                0 0 80px #00fff9, 0 0 90px #00fff9, 0 0 100px #00fff9;
        }

        .loader span {
            position: absolute;
            inset: 20px;
            background: #000;
            border-radius: 50%;
            z-index: 1;
        }

        .loader-container2 .loader1:before,
        .loader-container2 .loader2:before {
            content: "";
            position: absolute;
            top: 0;
            left: 0;
            width: 50%;
            height: 100%;
            background: linear-gradient(to top, transparent, rgba(250, 169, 158, 0.5));
            background-size: 100px 180px;
            background-repeat: no-repeat;
            border-top-left-radius: 100px;
            border-bottom-left-radius: 100px;
        }

        .loader-container2 .loader2,
        .loader-container2 .loader4 {
            animation-delay: -1s;
            filter: hue-rotate(290deg);
        }

        .loader-container2 .loader i {
            position: absolute;
            top: 0;
            left: 50%;
            transform: translateX(-50%);
            width: 20px;
            height: 20px;
            background: #ffa59e;
            border-radius: 50%;
            z-index: 100;
            box-shadow: 0 0 10px #ffb0ab, 0 0 20px #ffb0ab, 0 0 30px #ffb0ab,
                0 0 40px #ffb0ab, 0 0 50px #ffb0ab, 0 0 60px #ffb0ab, 0 0 70px #ffb0ab,
                0 0 80px #ffb0ab, 0 0 90px #ffb0ab, 0 0 100px #ffb0ab;
        }

        .loader-container2 .loader span {
            position: absolute;
            inset: 20px;
            background: #000;
            border-radius: 50%;
            z-index: 1;
        }
    </style>
</head>

<body>
    <div class="loader-container">
        <div class="loader loader1"><span></span></div>
        <div class="loader loader2"><span></span></div>
        <div class="loader loader3"><i></i></div>
        <div class="loader loader4"><i></i></div>
    </div>
    <div class="loader-container loader-container2">
        <div class="loader loader1"><span></span></div>
        <div class="loader loader2"><span></span></div>
        <div class="loader loader3"><i></i></div>
        <div class="loader loader4"><i></i></div>
    </div>
</body>

</html>

HTML 结构

  • loader-container:包含一组加载动画。
  • loader loader1:定义了一个加载动画,包含一个span元素。
  • loader loader2:定义了另一个加载动画,包含一个span元素。
  • loader loader3:定义了第三个加载动画,包含一个i元素。
  • loader loader4:定义了第四个加载动画,包含一个i元素。
  • loader-container loader-container2:包含另一组加载动画,样式与第一组略有不同。包含与第一组相同的四个加载动画,但使用了不同的颜色和渐变效果。

CSS 样式

  • .loader-container:设置为相对定位。使用Flexbox布局,居中显示内容。设置高度为200px。使用-webkit-box-reflect属性添加反射效果。

  • .loader:设置为绝对定位。定义了宽度和高度,设置为圆形(border-radius: 50%)。使用animation属性应用旋转动画。

  • .loader1:before, .loader2:before:定义了伪元素,用于创建渐变效果。设置为绝对定位,覆盖加载动画的一半。使用linear-gradient定义渐变背景。

  • .loader2, .loader4:设置动画延迟为-1秒。应用色相旋转滤镜(filter: hue-rotate(290deg))。

  • .loader i:定义了一个绝对定位的圆点,用于创建光点效果。设置了背景颜色和阴影效果。

  • .loader span:定义了一个绝对定位的圆形元素,用于覆盖加载动画的中心部分。设置背景颜色为黑色。


各位互联网搭子,要是这篇文章成功引起了你的注意,别犹豫,关注、点赞、评论、分享走一波,让我们把这份默契延续下去,一起在知识的海洋里乘风破浪!

相关推荐
itsOli35 分钟前
(20)详情页开发——② 公用图片画廊组件 | Vue.js 项目实战: 移动端“旅游网站”开发
前端·javascript·vue.js
Riesenzahn37 分钟前
说说你对JSBridge的理解
前端·javascript
烛阴41 分钟前
Express 中间件:Node.js 开发的得力助手
前端·javascript·express
百锦再1 小时前
Reactive编程框架与工具
前端·javascript·python·django·vue·框架·react
江城开朗的豌豆1 小时前
CSS篇:移动端适配必学:750设计图的px到rem精准换算方法
前端·css·面试
ChinaRainbowSea1 小时前
9. RabbitMQ 消息队列幂等性,优先级队列,惰性队列的详细说明
java·javascript·分布式·后端·rabbitmq·ruby·java-rabbitmq
就是我1 小时前
JavaScript这几种内存泄露写法,你要小心了
前端·javascript·代码规范
日升1 小时前
时区转换工具+PWA离线网页
前端·javascript
那小孩儿1 小时前
还在每次都写判断?试试惰性函数,让你的代码更聪明!
前端·javascript
用户72526496629691 小时前
Cesium:加载本地高程/地形数据
javascript