CSS实现简单的音频播放动画

先上效果图:

HTML文件:

html 复制代码
<!DOCTYPE html>
<html lang="zh-CN">

<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>音频波形加载动画</title>
    
    <!-- CSS File -->
    <link rel="stylesheet" href="css/style.css">
</head>

<body>
    <main class="loader-container" role="main" aria-label="音频加载动画">
        <!-- JavaScript将在这里动态生成loader -->
    </main>
    
    <script>
        // 动态生成loader结构
        function createLoaders(count = 3, barsPerLoader = 5) {
            const container = document.querySelector('.loader-container');
            
            for (let i = 0; i < count; i++) {
                const loader = document.createElement('div');
                loader.className = 'loader';
                loader.setAttribute('aria-label', `音频波形 ${i + 1}`);
                
                for (let j = 0; j < barsPerLoader; j++) {
                    const span = document.createElement('span');
                    span.setAttribute('aria-hidden', 'true');
                    loader.appendChild(span);
                }
                
                container.appendChild(loader);
            }
        }
        
        // 页面加载完成后生成结构
        document.addEventListener('DOMContentLoaded', () => {
            createLoaders();
        });
    </script>
</body>

</html>

css文件:

css 复制代码
/* 全局重置 */
* {
    margin: 0;
    padding: 0;
    box-sizing: border-box;
}

/* 页面布局 */
body {
    height: 100vh;
    display: grid;
    place-items: center;
    background: #100f13;
    font-family: Arial, sans-serif;
}

/* Loader容器 - 支持多个loader并排显示 */
.loader-container {
    display: flex;
    align-items: center;
    justify-content: center;
}

/* 单个Loader */
.loader {
    height: 90px;
    display: flex;
    align-items: center;
    transform: rotate(180deg);
}

/* Loader中的条形元素 */
.loader span {
    width: 5px;
    margin: 0 4px;
    border-radius: 4px;
    background: #ffffff;
    will-change: height; /* 性能优化 */
}

/* 音频波形动画定义 - 使用CSS变量优化 */
@keyframes audioWave {
    0%, 100% { 
        height: calc(var(--base-height) * 1px); 
    }
    12% { 
        height: calc(var(--peak1) * 1px); 
    }
    25% { 
        height: calc(var(--valley1) * 1px); 
    }
    37% { 
        height: calc(var(--peak2) * 1px); 
    }
    50% { 
        height: calc(var(--valley2) * 1px); 
    }
    62% { 
        height: calc(var(--peak3) * 1px); 
    }
    75% { 
        height: calc(var(--valley3) * 1px); 
    }
    87% { 
        height: calc(var(--peak4) * 1px); 
    }
}

/* 每个span的音频波形动画 - 使用CSS变量复用 */
.loader span:nth-child(1) {
    --base-height: 12;
    --peak1: 68; --valley1: 25; --peak2: 82;
    --valley2: 18; --peak3: 90; --valley3: 35; --peak4: 45;
    animation: audioWave 1.8s infinite;
    animation-delay: 0.1s;
}

.loader span:nth-child(2) {
    --base-height: 20;
    --peak1: 45; --valley1: 85; --peak2: 30;
    --valley2: 95; --peak3: 15; --valley3: 75; --peak4: 60;
    animation: audioWave 2.3s infinite;
    animation-delay: 0.7s;
}

.loader span:nth-child(3) {
    --base-height: 18;
    --peak1: 78; --valley1: 40; --peak2: 88;
    --valley2: 22; --peak3: 65; --valley3: 50; --peak4: 70;
    animation: audioWave 1.9s infinite;
    animation-delay: 0.3s;
}

.loader span:nth-child(4) {
    --base-height: 15;
    --peak1: 92; --valley1: 35; --peak2: 70;
    --valley2: 25; --peak3: 85; --valley3: 50; --peak4: 65;
    animation: audioWave 2.1s infinite;
    animation-delay: 0.9s;
}

.loader span:nth-child(5) {
    --base-height: 25;
    --peak1: 55; --valley1: 90; --peak2: 20;
    --valley2: 80; --peak3: 40; --valley3: 95; --peak4: 75;
    animation: audioWave 2.4s infinite;
    animation-delay: 0.5s;
}

/* 多个loader的动画延迟 */
.loader:nth-child(2) {
    animation-delay: 0.3s;
}

.loader:nth-child(3) {
    animation-delay: 0.6s;
}

喜欢的话比个心呦! :)

相关推荐
qiao若huan喜7 小时前
10、webgl 基本概念 + 坐标系统 + 立方体
前端·javascript·信息可视化·webgl
前端一课8 小时前
Vue3 的 Composition API 和 Options API 有哪些区别?举例说明 Composition API 的优势。
前端
用户47949283569158 小时前
都说node.js是事件驱动的,什么是事件驱动?
前端·node.js
晴殇i8 小时前
前端架构中的中间层设计:构建稳健可维护的组件体系
前端·面试·代码规范
申阳8 小时前
Day 7:05. 基于Nuxt开发博客项目-首页开发
前端·后端·程序员
Crystal3288 小时前
App端用户每日弹出签到弹窗如何实现?(uniapp+Vue)
前端·vue.js
摸着石头过河的石头8 小时前
Service Worker 深度解析:让你的 Web 应用离线也能飞
前端·javascript·性能优化
用户4099322502128 小时前
Vue 3中watch侦听器的正确使用姿势你掌握了吗?深度监听、与watchEffect的差异及常见报错解析
前端·ai编程·trae
1024小神8 小时前
Xcode 常用使用技巧说明,总有一个帮助你
前端
政采云技术9 小时前
音视频通用组件设计探索和应用
前端·音视频开发