0

0

利用CSS动画与JavaScript实现动态颜色闪烁效果教程

聖光之護

聖光之護

发布时间:2025-12-05 12:51:23

|

730人浏览过

|

来源于php中文网

原创

利用CSS动画与JavaScript实现动态颜色闪烁效果教程

本教程详细阐述如何通过纯css动画结合少量javascript代码,实现元素动态、可重复的颜色闪烁效果,避免引入大型第三方库。核心思想是利用css的`@keyframes`定义完整的动画序列,并通过javascript在点击事件中添加和移除控制动画的css类,同时监听`animationend`事件以确保动画的可重复性。这种方法提供了高效、灵活且易于维护的解决方案。

前端开发中,我们经常需要为用户界面添加动态效果,例如当用户点击按钮时,某个元素能够短暂地改变颜色,然后恢复到初始状态。直接使用CSS的transition属性配合JavaScript来尝试实现这种“闪烁”或“先变蓝再变红”的序列效果,往往会遇到挑战。例如,连续设置两个css()调用来改变颜色并期望它们按顺序执行过渡,通常只会显示最后一个状态,因为浏览器在同一事件循环中会合并这些样式更新。

为了高效且优雅地实现这类动态效果,特别是需要重复触发的动画,推荐的方法是利用CSS的@keyframes动画结合JavaScript来控制动画的播放。这种方法将动画的定义与触发机制分离,使得代码更清晰、更易于维护,并且性能通常也更好。

核心概念:CSS动画与JavaScript触发

该方法的核心在于:

  1. CSS @keyframes定义动画序列:在CSS中定义一个完整的动画序列,包括起始、中间和结束状态。这使得颜色从初始状态到目标状态再回到初始状态的过程可以在CSS中一次性描述。
  2. JavaScript控制动画播放:通过JavaScript在用户交互时(例如点击按钮)为目标元素添加一个特定的CSS类。这个类会触发之前定义好的CSS动画。
  3. 监听animationend事件:当动画播放完毕后,通过监听animationend事件,JavaScript可以移除之前添加的CSS类,从而使动画可以再次被触发。

实施步骤

我们将通过一个示例来演示如何实现点击按钮时,页面背景色从红色闪烁到蓝色再回到红色的效果。

立即学习Java免费学习笔记(深入)”;

1. HTML结构

首先,我们需要一个按钮来触发动画,以及一个目标元素(这里以body为例)来显示颜色变化。

玻尔
玻尔

专注于科研领域的AI文献助手和学术搜索平台

下载
<button class="my-button">点击我</button>

2. CSS动画定义

接下来,我们定义页面的初始样式和动画效果。

body {
  margin: 0;
  background-color: #f00; /* 初始背景色:红色 */
  display: flex;
  min-height: 100vh;
}

.my-button {
  margin: auto;
  background-color: white;
  border: none;
  border-radius: 3px;
  padding: 10px 20px;
  transition: .2s;
  box-shadow: 1px 1px 4px rgba(0, 0, 0, .5);
  cursor: pointer; /* 添加光标提示 */
}

.my-button:hover {
  background-color: #ddd;
}

/* 定义闪烁动画 */
@keyframes bganim {
  0%, 100% {
    background-color: #f00; /* 动画开始和结束时为红色 */
  }
  50% {
    background-color: #00f; /* 动画中途(50%)时为蓝色 */
  }
}

/* 激活动画的类 */
.active {
  animation: bganim .6s forwards; /* 应用bganim动画,持续0.6秒,并保持动画结束状态 */
}

CSS解释:

  • body:设置初始背景色为红色(#f00)。
  • @keyframes bganim:定义了一个名为bganim的关键帧动画。
    • 0%, 100%:表示动画开始和结束时,background-color为红色。
    • 50%:表示动画进行到一半时,background-color变为蓝色(#00f)。
    • 这个定义确保了颜色从红 -> 蓝 -> 红的完整循环。
  • .active:这是一个控制类。当这个类被添加到元素上时,它会触发bganim动画。animation: bganim .6s forwards;表示动画名为bganim,持续时间为0.6秒,forwards确保动画结束后元素保持在动画的最终状态(虽然这里100%是初始状态,但forwards通常是一个好习惯)。

3. JavaScript控制逻辑

最后,使用JavaScript来监听按钮点击事件,并动态添加/移除.active类。

const button = document.querySelector('.my-button');
const targetElement = document.body; // 动画目标元素

button.addEventListener('click', function() {
  // 如果动画正在进行,先移除类再添加,确保动画可以重新触发
  if (targetElement.classList.contains('active')) {
    targetElement.classList.remove('active');
    // 强制浏览器重绘以重新开始动画
    void targetElement.offsetWidth; 
  }
  targetElement.classList.add('active');
});

targetElement.addEventListener('animationend', function() {
  targetElement.classList.remove('active');
});

JavaScript解释:

  • document.querySelector('.my-button'):获取按钮元素。
  • document.body:指定动画的目标元素为body。
  • button.addEventListener('click', function() { ... }):当按钮被点击时执行回调函数
    • 在回调函数内部,我们首先检查targetElement是否已经包含active类。如果包含,说明动画可能正在进行或刚结束,为了确保动画能够重新播放,我们先移除active类。
    • void targetElement.offsetWidth;:这是一个小技巧,通过访问元素的某个属性(如offsetWidth)来强制浏览器进行重绘,从而“重置”动画状态,确保即使在动画结束前再次点击也能重新播放。
    • targetElement.classList.add('active'):为目标元素添加active类,从而触发CSS动画。
  • targetElement.addEventListener('animationend', function() { ... }):监听目标元素的animationend事件。当动画播放完毕后,这个事件会被触发。
    • targetElement.classList.remove('active'):在动画结束后移除active类。这是关键一步,它使得动画可以再次被触发,因为下次点击时,active类可以重新被添加。

完整示例代码

将上述HTML、CSS和JavaScript代码组合,即可得到一个完整的、可运行的示例:

<!DOCTYPE html>
<html lang="zh-CN">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>CSS动画与JS实现颜色闪烁</title>
    <style>
        body {
            margin: 0;
            background-color: #f00; /* 初始背景色:红色 */
            display: flex;
            min-height: 100vh;
            transition: background-color 0.2s ease; /* 为非动画状态的颜色变化添加过渡 */
        }

        .my-button {
            margin: auto;
            background-color: white;
            border: none;
            border-radius: 3px;
            padding: 10px 20px;
            transition: .2s;
            box-shadow: 1px 1px 4px rgba(0, 0, 0, .5);
            cursor: pointer;
        }

        .my-button:hover {
            background-color: #ddd;
        }

        /* 定义闪烁动画 */
        @keyframes bganim {
            0%, 100% {
                background-color: #f00; /* 动画开始和结束时为红色 */
            }
            50% {
                background-color: #00f; /* 动画中途(50%)时为蓝色 */
            }
        }

        /* 激活动画的类 */
        .active {
            animation: bganim .6s forwards; /* 应用bganim动画,持续0.6秒,并保持动画结束状态 */
        }
    </style>
</head>
<body>
    <button class="my-button">点击我</button>

    <script>
        const button = document.querySelector('.my-button');
        const targetElement = document.body; // 动画目标元素

        button.addEventListener('click', function() {
            // 如果动画正在进行,先移除类再添加,确保动画可以重新触发
            if (targetElement.classList.contains('active')) {
                targetElement.classList.remove('active');
                // 强制浏览器重绘以重新开始动画
                void targetElement.offsetWidth; 
            }
            targetElement.classList.add('active');
        });

        targetElement.addEventListener('animationend', function() {
            targetElement.classList.remove('active');
        });
    </script>
</body>
</html>

注意事项与总结

  1. 分离关注点:这种方法将动画的视觉表现(CSS)与动画的触发逻辑(JavaScript)清晰地分离,提高了代码的可读性和可维护性。
  2. 性能优化:CSS动画通常由浏览器进行硬件加速,相比于通过JavaScript频繁修改样式属性,性能表现更优。
  3. 可重复性:通过监听animationend事件并在动画结束后移除控制类,确保了动画可以被反复触发,而不会因为类一直存在而无法再次播放。
  4. 强制重绘:在某些情况下,如果动画在结束前被再次触发,浏览器可能不会立即重新播放动画。void element.offsetWidth;(或offsetHeight、scrollWidth等)这个小技巧可以强制浏览器重新计算布局并重绘,从而确保动画能够立即重新开始。
  5. 目标元素:示例中以body作为目标元素,但你可以将.active类和animationend监听器应用于任何你希望进行动画的元素。
  6. 动画属性:@keyframes不仅可以动画background-color,还可以动画几乎所有可动画的CSS属性,如color、transform、opacity、width、height等。只需在@keyframes中定义相应的属性变化即可。

通过上述方法,我们可以轻松实现各种复杂的、可重复的动态UI效果,而无需依赖大型JavaScript库,保持项目的轻量和高效。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
javascriptvoid(o)怎么解决
javascriptvoid(o)怎么解决

javascriptvoid(o)的解决办法:1、检查语法错误;2、确保正确的执行环境;3、检查其他代码的冲突;4、使用事件委托;5、使用其他绑定方式;6、检查外部资源等等。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

186

2023.11.23

java中void的含义
java中void的含义

本专题整合了Java中void的相关内容,阅读专题下面的文章了解更多详细内容。

134

2025.11.27

function是什么
function是什么

function是函数的意思,是一段具有特定功能的可重复使用的代码块,是程序的基本组成单元之一,可以接受输入参数,执行特定的操作,并返回结果。本专题为大家提供function是什么的相关的文章、下载、课程内容,供大家免费下载体验。

499

2023.08.04

js函数function用法
js函数function用法

js函数function用法有:1、声明函数;2、调用函数;3、函数参数;4、函数返回值;5、匿名函数;6、函数作为参数;7、函数作用域;8、递归函数。本专题提供js函数function用法的相关文章内容,大家可以免费阅读。

166

2023.10.07

css3transition
css3transition

css3transition属性用于指定如何从一个CSS样式过渡到另一个CSS样式,本专题为大家提供transition相关的文章、相关下载和相关课程,大家可以免费体验。

261

2023.06.27

PHP 高并发与性能优化
PHP 高并发与性能优化

本专题聚焦 PHP 在高并发场景下的性能优化与系统调优,内容涵盖 Nginx 与 PHP-FPM 优化、Opcode 缓存、Redis/Memcached 应用、异步任务队列、数据库优化、代码性能分析与瓶颈排查。通过实战案例(如高并发接口优化、缓存系统设计、秒杀活动实现),帮助学习者掌握 构建高性能PHP后端系统的核心能力。

112

2025.10.16

PHP 数据库操作与性能优化
PHP 数据库操作与性能优化

本专题聚焦于PHP在数据库开发中的核心应用,详细讲解PDO与MySQLi的使用方法、预处理语句、事务控制与安全防注入策略。同时深入分析SQL查询优化、索引设计、慢查询排查等性能提升手段。通过实战案例帮助开发者构建高效、安全、可扩展的PHP数据库应用系统。

99

2025.11.13

JavaScript 性能优化与前端调优
JavaScript 性能优化与前端调优

本专题系统讲解 JavaScript 性能优化的核心技术,涵盖页面加载优化、异步编程、内存管理、事件代理、代码分割、懒加载、浏览器缓存机制等。通过多个实际项目示例,帮助开发者掌握 如何通过前端调优提升网站性能,减少加载时间,提高用户体验与页面响应速度。

36

2025.12.30

C# ASP.NET Core微服务架构与API网关实践
C# ASP.NET Core微服务架构与API网关实践

本专题围绕 C# 在现代后端架构中的微服务实践展开,系统讲解基于 ASP.NET Core 构建可扩展服务体系的核心方法。内容涵盖服务拆分策略、RESTful API 设计、服务间通信、API 网关统一入口管理以及服务治理机制。通过真实项目案例,帮助开发者掌握构建高可用微服务系统的关键技术,提高系统的可扩展性与维护效率。

76

2026.03.11

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
Sass 教程
Sass 教程

共14课时 | 0.9万人学习

Bootstrap 5教程
Bootstrap 5教程

共46课时 | 3.6万人学习

CSS教程
CSS教程

共754课时 | 42.2万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号