0

0

如何通过css animation-name指定动画名称

P粉602998670

P粉602998670

发布时间:2025-09-21 11:22:01

|

781人浏览过

|

来源于php中文网

原创

答案是通过animation-name属性将@keyframes定义的动画绑定到元素,结合JavaScript可实现动态控制。首先定义@keyframes动画序列并命名,如slideIn;然后在CSS中使用animation-name引用该名称,并配合duration、timing-function等属性设定动画效果,推荐使用animation简写提升代码简洁性;当animation-name值无效或拼写错误时动画不生效,需确保名称一致且合法;支持多个动画逗号分隔,属性按序对应,注意避免属性冲突;可通过JavaScript直接修改style.animationName或更优地通过添加/移除CSS类来动态控制动画触发,后者利于样式与逻辑分离,便于维护。

如何通过css animation-name指定动画名称

CSS的

animation-name
属性是连接元素与动画定义(
@keyframes
规则)的关键,它明确告诉浏览器哪个预定义的动画序列应该应用到这个特定的HTML元素上。没有它,即便你写好了再精妙的
@keyframes
,元素也无从知晓该“动”起来。

解决方案

要通过

css animation-name
指定动画名称,核心操作就是将你定义好的
@keyframes
规则的名称,赋值给目标元素的
animation-name
属性。这听起来可能有点像编程里的函数调用,你先定义一个函数(
@keyframes
),然后通过名字去调用它(
animation-name
)。

具体来说,你需要两步:

  1. 定义动画序列:使用

    @keyframes
    规则来创建你的动画。这里你需要给它一个独一无二的名字。

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

    @keyframes slideIn {
      from {
        transform: translateX(-100%);
        opacity: 0;
      }
      to {
        transform: translateX(0);
        opacity: 1;
      }
    }

    在这个例子里,动画的名字就是

    slideIn

  2. 应用动画:在你想应用这个动画的CSS选择器中,设置

    animation-name
    属性为你在
    @keyframes
    中定义的名字。

    .my-element {
      animation-name: slideIn; /* 告诉浏览器,我要用slideIn这个动画 */
      animation-duration: 1s; /* 动画持续时间 */
      animation-timing-function: ease-out; /* 动画速度曲线 */
      animation-fill-mode: forwards; /* 动画结束后保持最终状态 */
    }

    这样,

    .my-element
    就会按照
    slideIn
    这个动画序列动起来。当然,
    animation-duration
    animation-timing-function
    等其他动画属性也是必不可少的,它们共同构成了完整的动画效果。你可以把它们写在一起,也可以使用
    animation
    这个简写属性。

    .my-element-shorthand {
      animation: slideIn 1s ease-out forwards;
    }

    说实话,我个人更偏爱简写,代码量小,一眼就能看出是个动画。但对于初学者或者需要覆盖大量动画属性时,拆开写也挺清晰的。

理解CSS动画名称(animation-name)与@keyframes规则的绑定机制

这个绑定机制,在我看来,是CSS动画的基石。没有它,CSS动画就无从谈起。

animation-name
属性就像一个“索引”,它指向了你用
@keyframes
定义好的具体动画指令集。

当你写下

@keyframes myAnimation { ... }
时,你实际上是在全局范围内注册了一个名为
myAnimation
的动画蓝图。这个蓝图包含了动画从开始(
from
0%
)到结束(
to
100%
)之间,元素各个CSS属性的变化过程。比如,一个元素从左边滑入,或者颜色从红变蓝,这些都是在
@keyframes
里描述的。

然后,当你在一个元素上设置

animation-name: myAnimation;
时,浏览器就会去查找这个名为
myAnimation
的蓝图,并根据蓝图的指示,结合其他
animation
属性(比如持续时间、延迟、循环次数等),来执行动画。

Tellers AI
Tellers AI

Tellers是一款自动视频编辑工具,可以将文本、文章或故事转换为视频。

下载

如果

animation-name
指定的名字在你的CSS中找不到对应的
@keyframes
规则,那么这个动画就不会播放,就好像你调用了一个不存在的函数一样。浏览器通常会静默失败,不会报错,这在调试时可能会让人头疼。我记得有一次,我把
@keyframes
的名字写成了
slide-in
,结果在
animation-name
里写成了
slideIn
(驼峰命名),结果动画死活不出来,最后才发现是大小写不匹配。这种小错误,尤其是在团队协作或者复制粘贴代码时,特别容易发生。所以,命名一致性非常重要。

另外,

@keyframes
的名称必须是有效的CSS标识符,这意味着它们可以包含字母、数字、下划线(
_
)和连字符(
-
),但不能以数字开头,也不能包含空格。

当animation-name值无效或冲突时,动画行为会如何?

这部分内容,我觉得特别有实用价值,因为这是我们日常开发中经常会遇到的“坑”。

  1. 无效的

    animation-name

    • 名称不存在:如果
      animation-name
      指向的
      @keyframes
      规则不存在,浏览器会直接忽略这个动画属性,动画不会发生。元素会保持其初始状态。这通常是最常见的情况,也是最容易调试的,因为你只需要检查
      animation-name
      的值是否与
      @keyframes
      的名称完全匹配。
    • 名称非法:如果
      animation-name
      的值本身就不是一个有效的CSS标识符(比如包含空格、以数字开头等),那么整个
      animation-name
      属性声明就会被浏览器视为无效,同样动画不会播放。
  2. 多个

    animation-name

    • CSS允许你为一个元素指定多个动画。你只需要在
      animation-name
      属性中用逗号分隔不同的动画名称即可。
      .my-element-multi {
        animation-name: fadeIn, bounce; /* 同时应用fadeIn和bounce两个动画 */
        animation-duration: 1s, 0.5s;
        animation-delay: 0s, 1s;
        /* 其他动画属性也需要按顺序用逗号分隔 */
      }
    • 当指定多个动画时,每个动画的属性值(如
      animation-duration
      animation-delay
      等)也需要用逗号分隔,并且顺序要与
      animation-name
      中动画名称的顺序一一对应。如果某个属性的值数量少于
      animation-name
      的数量,那么它会循环使用已有的值。
    • 冲突:多个动画在同一个元素上同时播放时,可能会出现属性冲突。例如,如果
      fadeIn
      动画改变了
      opacity
      bounce
      动画也改变了
      opacity
      ,那么哪个动画的
      opacity
      会生效呢?CSS的层叠规则会在这里发挥作用,但通常情况下,后声明的动画(在
      animation-name
      列表中靠后的)会覆盖先声明的动画中相同的属性
      。 不过,更常见的情况是,不同的动画会改变不同的属性,或者以一种互补的方式进行。比如,一个动画负责位移,另一个负责旋转。如果它们都试图改变同一个属性,那么效果可能会比较混乱,需要仔细设计动画的逻辑。我通常会尽量让每个动画专注于改变不同的CSS属性集,这样可以减少冲突,也更容易管理。

如何利用JavaScript动态控制或修改animation-name?

在很多交互场景中,我们不希望动画一开始就播放,而是希望在用户点击、滚动到特定区域,或者数据加载完成后才触发。这时候,JavaScript就成了动态控制

animation-name
的最佳工具

主要有两种方法:

  1. 直接修改

    style.animationName
    属性: 这是最直接的方式。你可以获取到DOM元素,然后直接修改它的
    style.animationName
    属性。

    const myElement = document.querySelector('.dynamic-animation-element');
    
    // 假设我们已经定义了 @keyframes fadeIn 和 @keyframes slideUp
    function triggerFadeIn() {
      myElement.style.animationName = 'fadeIn';
      myElement.style.animationDuration = '1s';
      myElement.style.animationFillMode = 'forwards';
      // 动画一旦播放完,如果想再次触发,可能需要先清空animationName或者重置状态
      // myElement.style.animationName = 'none'; // 重置
    }
    
    function triggerSlideUp() {
      myElement.style.animationName = 'slideUp';
      myElement.style.animationDuration = '0.8s';
      myElement.style.animationFillMode = 'forwards';
    }
    
    // 比如,点击按钮触发动画
    document.getElementById('fadeInButton').addEventListener('click', triggerFadeIn);
    document.getElementById('slideUpButton').addEventListener('click', triggerSlideUp);

    这种方法的优点是直观、控制力强。缺点是如果你有多个动画属性需要设置,代码可能会显得有点冗长。而且,如果你想在动画结束后移除动画属性以便下次重新触发,或者切换到另一个动画,需要手动管理。

  2. 通过添加/移除CSS类来控制: 这是我个人更偏爱的方式,因为它将动画的样式定义与JavaScript的逻辑分离,使得CSS更纯粹,JavaScript更专注于行为控制。

    首先,在CSS中定义包含动画的类:

    .dynamic-animation-element {
      /* 初始状态 */
      opacity: 0;
      transform: translateY(20px);
    }
    
    .is-fading-in {
      animation-name: fadeIn;
      animation-duration: 1s;
      animation-fill-mode: forwards;
      animation-timing-function: ease-out;
    }
    
    .is-sliding-up {
      animation-name: slideUp;
      animation-duration: 0.8s;
      animation-fill-mode: forwards;
      animation-timing-function: cubic-bezier(0.68, -0.55, 0.27, 1.55); /* 一个有点弹跳效果的曲线 */
    }
    
    @keyframes fadeIn {
      from { opacity: 0; }
      to { opacity: 1; }
    }
    
    @keyframes slideUp {
      from { transform: translateY(20px); opacity: 0; }
      to { transform: translateY(0); opacity: 1; }
    }

    然后,在JavaScript中通过添加或移除这些类来触发动画:

    const myElementClass = document.querySelector('.dynamic-animation-element');
    
    document.getElementById('fadeInButtonClass').addEventListener('click', () => {
      myElementClass.classList.remove('is-sliding-up'); // 确保移除其他可能的动画类
      myElementClass.classList.add('is-fading-in');
    });
    
    document.getElementById('slideUpButtonClass').addEventListener('click', () => {
      myElementClass.classList.remove('is-fading-in');
      myElementClass.classList.add('is-sliding-up');
    });
    
    // 如果想在动画结束后做些什么,可以监听animationend事件
    myElementClass.addEventListener('animationend', (event) => {
      if (event.animationName === 'fadeIn') {
        console.log('FadeIn animation finished!');
        // 动画完成后,如果你想移除动画类以便下次重新触发,可以这样做
        // myElementClass.classList.remove('is-fading-in');
      }
    });

    这种类名切换的方式,好处在于CSS和JS职责分离,代码更清晰,也更容易维护。当动画结束后,你可以选择移除对应的类名,让元素回到初始状态,或者为下一次动画做准备。这种模式在构建复杂交互和状态管理时非常有用。

相关专题

更多
js获取数组长度的方法
js获取数组长度的方法

在js中,可以利用array对象的length属性来获取数组长度,该属性可设置或返回数组中元素的数目,只需要使用“array.length”语句即可返回表示数组对象的元素个数的数值,也就是长度值。php中文网还提供JavaScript数组的相关下载、相关课程等内容,供大家免费下载使用。

556

2023.06.20

js刷新当前页面
js刷新当前页面

js刷新当前页面的方法:1、reload方法,该方法强迫浏览器刷新当前页面,语法为“location.reload([bForceGet]) ”;2、replace方法,该方法通过指定URL替换当前缓存在历史里(客户端)的项目,因此当使用replace方法之后,不能通过“前进”和“后退”来访问已经被替换的URL,语法为“location.replace(URL) ”。php中文网为大家带来了js刷新当前页面的相关知识、以及相关文章等内容

374

2023.07.04

js四舍五入
js四舍五入

js四舍五入的方法:1、tofixed方法,可把 Number 四舍五入为指定小数位数的数字;2、round() 方法,可把一个数字舍入为最接近的整数。php中文网为大家带来了js四舍五入的相关知识、以及相关文章等内容

732

2023.07.04

js删除节点的方法
js删除节点的方法

js删除节点的方法有:1、removeChild()方法,用于从父节点中移除指定的子节点,它需要两个参数,第一个参数是要删除的子节点,第二个参数是父节点;2、parentNode.removeChild()方法,可以直接通过父节点调用来删除子节点;3、remove()方法,可以直接删除节点,而无需指定父节点;4、innerHTML属性,用于删除节点的内容。

477

2023.09.01

JavaScript转义字符
JavaScript转义字符

JavaScript中的转义字符是反斜杠和引号,可以在字符串中表示特殊字符或改变字符的含义。本专题为大家提供转义字符相关的文章、下载、课程内容,供大家免费下载体验。

414

2023.09.04

js生成随机数的方法
js生成随机数的方法

js生成随机数的方法有:1、使用random函数生成0-1之间的随机数;2、使用random函数和特定范围来生成随机整数;3、使用random函数和round函数生成0-99之间的随机整数;4、使用random函数和其他函数生成更复杂的随机数;5、使用random函数和其他函数生成范围内的随机小数;6、使用random函数和其他函数生成范围内的随机整数或小数。

991

2023.09.04

如何启用JavaScript
如何启用JavaScript

JavaScript启用方法有内联脚本、内部脚本、外部脚本和异步加载。详细介绍:1、内联脚本是将JavaScript代码直接嵌入到HTML标签中;2、内部脚本是将JavaScript代码放置在HTML文件的`<script>`标签中;3、外部脚本是将JavaScript代码放置在一个独立的文件;4、外部脚本是将JavaScript代码放置在一个独立的文件。

658

2023.09.12

Js中Symbol类详解
Js中Symbol类详解

javascript中的Symbol数据类型是一种基本数据类型,用于表示独一无二的值。Symbol的特点:1、独一无二,每个Symbol值都是唯一的,不会与其他任何值相等;2、不可变性,Symbol值一旦创建,就不能修改或者重新赋值;3、隐藏性,Symbol值不会被隐式转换为其他类型;4、无法枚举,Symbol值作为对象的属性名时,默认是不可枚举的。

552

2023.09.20

高德地图升级方法汇总
高德地图升级方法汇总

本专题整合了高德地图升级相关教程,阅读专题下面的文章了解更多详细内容。

72

2026.01.16

热门下载

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

精品课程

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

共14课时 | 0.8万人学习

Bootstrap 5教程
Bootstrap 5教程

共46课时 | 2.9万人学习

CSS教程
CSS教程

共754课时 | 20.5万人学习

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

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