当前位置: 首页 > article >正文

HTMLCSS :下雪了

这段代码创建了一个动态的雪花飘落加载动画,通过 CSS 技术实现了雪花的下落和消失效果,为页面添加了视觉吸引力和动态感。


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

演示效果

在这里插入图片描述

HTML&CSS

<!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>
        body {
            margin: 0;
            padding: 0;
            height: 100vh;
            display: flex;
            align-items: center;
            justify-content: center;
            position: relative;
            background: #212121;
        }

        .loader {
            position: relative;
            width: 110px;
            height: 30px;
            background: #fff;
            border-radius: 100px;
        }

        .loader::before {
            content: '';
            position: absolute;
            top: -20px;
            left: 10px;
            width: 30px;
            height: 30px;
            background: #fff;
            border-radius: 50%;
            box-shadow: 40px 0 0 20px #fff;
        }

        .snow {
            position: relative;
            display: flex;
            z-index: 1;
        }

        .snow span {
            position: relative;
            width: 3px;
            height: 3px;
            background: #fff;
            margin: 0 2px;
            border-radius: 50%;
            animation: snowing 5s linear infinite;
            animation-duration: calc(15s / var(--i));
            transform-origin: bottom;
        }

        @keyframes snowing {
            0% {
                transform: translateY(0px);
            }

            70% {
                transform: translateY(100px) scale(1);
            }

            100% {
                transform: translateY(100px) scale(0);
            }
        }
    </style>
</head>

<body>
    <div class="loader">
        <div class="snow">
            <span style="--i:11"></span>
            <span style="--i:12"></span>
            <span style="--i:15"></span>
            <span style="--i:17"></span>
            <span style="--i:18"></span>
            <span style="--i:13"></span>
            <span style="--i:14"></span>
            <span style="--i:19"></span>
            <span style="--i:20"></span>
            <span style="--i:10"></span>
            <span style="--i:18"></span>
            <span style="--i:13"></span>
            <span style="--i:14"></span>
            <span style="--i:19"></span>
            <span style="--i:20"></span>
            <span style="--i:10"></span>
            <span style="--i:18"></span>
            <span style="--i:13"></span>
            <span style="--i:14"></span>
            <span style="--i:19"></span>
            <span style="--i:20"></span>
            <span style="--i:10"></span>
        </div>
    </div>
</body>

</html>

HTML 结构

  • loader: 创建一个类名为“loader”的 div 元素,用于包含加载动画的各个部分。
  • snow: 创建一个类名为“snow”的 div 元素,用于包含所有雪花。
  • 每个 span 代表一个雪花,通过 style="–i:n"设置不同的动画持续时间。

CSS 样式

  • body: 设置页面的边距、填充、高度、显示方式和对齐方式,背景色为深灰色。
  • .loader: 设置加载动画的容器样式,包括位置、尺寸、背景色和圆角。
  • .loader::before: 设置一个圆形的伪元素,用于创建雪花飘落的起点,通过 box-shadow 创建多个雪花。
  • .snow: 设置雪花容器的样式,包括位置和显示方式。
  • .snow span: 设置每个雪花的样式,包括位置、尺寸、背景色、边距、圆角和动画效果。
  • animation: snowing 5s linear infinite: 应用雪花飘落的动画,持续时间为 15s / var(–i),使每个雪花的下落速度不同。
  • transform-origin: bottom: 设置雪花的变换原点为底部,使雪花从底部开始下落。@keyframes snowing: 定义雪花飘落的动画效果。0%: 雪花在初始位置。70%: 雪花下落 100 像素,并保持原始大小。100%: 雪花下落 100 像素,并逐渐消失(通过 scale(0))。

http://www.kler.cn/a/519713.html

相关文章:

  • Kafka运维宝典 (四)- Kafka 常用命令介绍
  • Vue.js 传递路由参数和查询参数
  • 传输层协议TCP与UDP:深入解析与对比
  • 「 机器人 」利用冲程对称性调节实现仿生飞行器姿态与方向控制
  • Formality:时序变换(四)(寄存器合并)
  • React将props传递给一个组件
  • 设计模式Python版 抽象工厂模式
  • sqlzoo答案4:SELECT within SELECT Tutorial
  • 【Leetcode刷题记录】15.三数之和
  • 【2024年华为OD机试】(A卷,200分)- 农场施肥 (JavaScriptJava PythonC/C++)
  • 2025年美赛(MCM/ICM)赛题浅析——助攻快速选题
  • 小智 AI 聊天机器人
  • Python读写各类数据文件
  • 学习数据结构(1)算法复杂度
  • JavaScript系列(44)--微服务架构实现详解
  • 【25考研】中科院软件考研复试难度分析!
  • leetcode 1358. 包含所有三种字符的子字符串数目
  • 【PostgreSQL内核学习 —— (WindowAgg(一))】
  • 基于vue框架的的信用社业务管理系统设计与实现4gnx5(程序+源码+数据库+调试部署+开发环境)带论文文档1万字以上,文末可获取,系统界面在最后面。
  • 包安装利用 LNMP 实现 phpMyAdmin 的负载均衡并利用Redis实现会话保持nginx