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

33次阅读

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

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

CSS的

-default'>-default'>-default'>-default'>-default'>-default'>animation-name

属性是连接元素与动画定义(

-default'>-default'>-default'>-default'>-default'>-default'>-default'>-default'>-default'>-default'>-default'>@keyframes

规则)的关键,它明确告诉浏览器哪个预定义的动画序列应该应用到这个特定的HTML元素上。没有它,即便你写好了再精妙的

-default'>-default'>-default'>-default'>-default'>-default'>-default'>-default'>-default'>-default'>-default'>@keyframes

,元素也无从知晓该“动”起来。

解决方案

要通过

css -default'>-default'>-default'>-default'>-default'>-default'>animation-name

指定动画名称,核心操作就是将你定义好的

-default'>-default'>-default'>-default'>-default'>-default'>-default'>-default'>-default'>-default'>-default'>@keyframes

规则的名称,赋值给目标元素的

-default'>-default'>-default'>-default'>-default'>-default'>animation-name

属性。这听起来可能有点像编程里的函数调用,你先定义一个函数(

-default'>-default'>-default'>-default'>-default'>-default'>-default'>-default'>-default'>-default'>-default'>@keyframes

),然后通过名字去调用它(

-default'>-default'>-default'>-default'>-default'>-default'>animation-name

)。

具体来说,你需要两步:

  1. 定义动画序列:使用

    -default'>-default'>-default'>-default'>-default'>-default'>-default'>-default'>-default'>-default'>-default'>@keyframes

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

    立即学习-decoration: underline !important; color: blue; font-weight: bolder;" rel="nofollow" target="-default'>_blank">前端免费学习笔记(深入)”;

    -default'>-default'>-default'>-default'>-default'>-default'>-default'>-default'>-default'>-default'>-default'>@keyframes -default'>-default'>-default'>slideIn {   -default'>from {     transform: translateX(-10-default'>0%);     opacity: 0;   }   -default'>to {     transform: translateX(0);     opacity: 1;   } }

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

    -default'>-default'>-default'>slideIn

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

    -default'>-default'>-default'>-default'>-default'>-default'>animation-name

    属性为你在

    -default'>-default'>-default'>-default'>-default'>-default'>-default'>-default'>-default'>-default'>-default'>@keyframes

    中定义的名字。

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

    这样,

    -default'>.my-element

    就会按照

    -default'>-default'>-default'>slideIn

    这个动画序列动起来。当然,

    -default'>-default'>-default'>animation-duration

    -default'>-default'>-default'>animation-timing-function

    等其他动画属性也是必不可少的,它们共同构成了完整的动画效果。你可以把它们写在一起,也可以使用

    -default'>-default'>animation

    这个简写属性。

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

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

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

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

-default'>-default'>-default'>-default'>-default'>-default'>animation-name

属性就像一个“索引”,它指向了你用

-default'>-default'>-default'>-default'>-default'>-default'>-default'>-default'>-default'>-default'>-default'>@keyframes

定义好的具体动画指令集。

当你写下

-default'>-default'>-default'>-default'>-default'>-default'>-default'>-default'>-default'>-default'>-default'>@keyframes -default'>-default'>myAnimation { ... }

时,你实际上是在全局范围内注册了一个名为

-default'>-default'>myAnimation

的动画蓝图。这个蓝图包含了动画从开始(

-default'>from

-default'>0%

)到结束(

-default'>to

10-default'>0%

)之间,元素各个CSS属性的变化过程。比如,一个元素从左边滑入,或者颜色从红变蓝,这些都是在

-default'>-default'>-default'>-default'>-default'>-default'>-default'>-default'>-default'>-default'>-default'>@keyframes

里描述的。

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

-default'>-default'>-default'>-default'>-default'>-default'>animation-name: -default'>-default'>myAnimation;

时,浏览器就会去查找这个名为

-default'>-default'>myAnimation

的蓝图,并根据蓝图的指示,结合其他

-default'>-default'>animation

属性(比如持续时间、延迟、循环次数等),来执行动画。

如果

-default'>-default'>-default'>-default'>-default'>-default'>animation-name

指定的名字在你的CSS中找不到对应的

-default'>-default'>-default'>-default'>-default'>-default'>-default'>-default'>-default'>-default'>-default'>@keyframes

规则,那么这个动画就不会播放,就好像你调用了一个不存在的函数一样。浏览器通常会静默失败,不会报错,这在调试时可能会让人头疼。我记得有一次,我把

-default'>-default'>-default'>-default'>-default'>-default'>-default'>-default'>-default'>-default'>-default'>@keyframes

的名字写成了

-default'>slide-in

,结果在

-default'>-default'>-default'>-default'>-default'>-default'>animation-name

里写成了

-default'>-default'>-default'>slideIn

(驼峰命名),结果动画死活不出来,最后才发现是大小写不匹配。这种小错误,尤其是在团队协作或者复制粘贴代码时,特别容易发生。所以,命名一致性非常重要。

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

Vimeo

Vimeo平台的在线视频生成工具

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

查看详情 如何通过css animation-name指定动画名称

另外,

-default'>-default'>-default'>-default'>-default'>-default'>-default'>-default'>-default'>-default'>-default'>@keyframes

的名称必须是有效的CSS标识符,这意味着它们可以包含字母、数字、下划线(

-default'>_

)和连字符(

-

),但不能以数字开头,也不能包含空格。

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

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

  1. 无效的

    -default'>-default'>-default'>-default'>-default'>-default'>animation-name

    • 名称不存在:如果
      -default'>-default'>-default'>-default'>-default'>-default'>animation-name

      指向的

      -default'>-default'>-default'>-default'>-default'>-default'>-default'>-default'>-default'>-default'>-default'>@keyframes

      规则不存在,浏览器会直接忽略这个动画属性,动画不会发生。元素会保持其初始状态。这通常是最常见的情况,也是最容易调试的,因为你只需要检查

      -default'>-default'>-default'>-default'>-default'>-default'>animation-name

      的值是否与

      -default'>-default'>-default'>-default'>-default'>-default'>-default'>-default'>-default'>-default'>-default'>@keyframes

      的名称完全匹配。

    • 名称非法:如果
      -default'>-default'>-default'>-default'>-default'>-default'>animation-name

      的值本身就不是一个有效的CSS标识符(比如包含空格、以数字开头等),那么整个

      -default'>-default'>-default'>-default'>-default'>-default'>animation-name

      属性声明就会被浏览器视为无效,同样动画不会播放。

  2. 多个

    -default'>-default'>-default'>-default'>-default'>-default'>animation-name

    • CSS允许你为一个元素指定多个动画。你只需要在
      -default'>-default'>-default'>-default'>-default'>-default'>animation-name

      属性中用逗号分隔不同的动画名称即可。

      -default'>.my-element-multi {   -default'>-default'>-default'>-default'>-default'>-default'>animation-name: fadeIn, bounce; /* 同时应用fadeInbounce两个动画 */   -default'>-default'>-default'>animation-duration: 1s, 0.5s;   -default'>-default'>animation-delay: 0s, 1s;   /* 其他动画属性也需要按顺序用逗号分隔 */ }
    • 当指定多个动画时,每个动画的属性值(如
      -default'>-default'>-default'>animation-duration

      -default'>-default'>animation-delay

      等)也需要用逗号分隔,并且顺序要与

      -default'>-default'>-default'>-default'>-default'>-default'>animation-name

      中动画名称的顺序一一对应。如果某个属性的值数量少于

      -default'>-default'>-default'>-default'>-default'>-default'>animation-name

      的数量,那么它会循环使用已有的值。

    • 冲突:多个动画在同一个元素上同时播放时,可能会出现属性冲突。例如,如果
      fadeIn

      动画改变了

      opacity

      bounce

      动画也改变了

      opacity

      ,那么哪个动画的

      opacity

      会生效呢?CSS的层叠规则会在这里发挥作用,但通常情况下,后声明的动画(在

      -default'>-default'>-default'>-default'>-default'>-default'>animation-name

      列表中靠后的)会覆盖先声明的动画中相同的属性。 不过,更常见的情况是,不同的动画会改变不同的属性,或者以一种互补的方式进行。比如,一个动画负责位移,另一个负责旋转。如果它们都试图改变同一个属性,那么效果可能会比较混乱,需要仔细设计动画的逻辑。我通常会尽量让每个动画专注于改变不同的CSS属性集,这样可以减少冲突,也更容易管理。

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

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

-default'>-default'>-default'>-default'>-default'>-default'>animation-name

的最佳工具

主要有两种方法:

  1. 直接修改

    style.-default'>-default'>animationName

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

    style.-default'>-default'>animationName

    属性。

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

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

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

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

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

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

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

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

以上就是如何通过css -data="/zt/15724.html" target="-default'>_blank">javascript -data="/zt/15731.html" target="-default'>_blank">java -data="/zt/15763.html" target="-default'>_blank">html -data="/zt/15802.html" target="-default'>_blank">js -data="/zt/16180.html" target="-default'>_blank">浏览器 -data="/zt/16887.html" target="-default'>_blank">工具 -data="/zt/17079.html" target="-default'>_blank">ssl -data="/zt/29015.html" target="-default'>_blank">css动画 -data="/zt/35764.html" target="-default'>_blank">css选择器 -data="/zt/60195.html" target="-default'>_blank">html元素 -data="/search?word=JavaScript" target="-default'>_blank">JavaScript -data="/search?word=css" target="-default'>_blank">css -data="/search?word=html" target="-default'>_blank">html -data="/search?word=标识符" target="-default'>_blank">标识符 -data="/search?word=循环" target="-default'>_blank">循环 -data="/search?word=JS" target="-default'>_blank">JS -data="/search?word=function" target="-default'>_blank">function -data="/search?word=dom" target="-default'>_blank">dom -data="/search?word=选择器" target="-default'>_blank">选择器 -data="/search?word=-default'>-default'>animation" target="-default'>_blank">-default'>-default'>animation

-data="/zt/15716.html" target="-default'>_blank">css -data="/zt/15724.html" target="-default'>_blank">javascript -data="/zt/15731.html" target="-default'>_blank">java -data="/zt/15763.html" target="-default'>_blank">html -data="/zt/15802.html" target="-default'>_blank">js -data="/zt/16180.html" target="-default'>_blank">浏览器 -data="/zt/16887.html" target="-default'>_blank">工具 -data="/zt/17079.html" target="-default'>_blank">ssl -data="/zt/29015.html" target="-default'>_blank">css动画 -data="/zt/35764.html" target="-default'>_blank">css选择器 -data="/zt/60195.html" target="-default'>_blank">html元素 -data="/search?word=JavaScript" target="-default'>_blank">JavaScript -data="/search?word=css" target="-default'>_blank">css -data="/search?word=html" target="-default'>_blank">html -data="/search?word=标识符" target="-default'>_blank">标识符 -data="/search?word=循环" target="-default'>_blank">循环 -data="/search?word=JS" target="-default'>_blank">JS -data="/search?word=function" target="-default'>_blank">function -data="/search?word=dom" target="-default'>_blank">dom -data="/search?word=选择器" target="-default'>_blank">选择器 -data="/search?word=-default'>-default'>animation" target="-default'>_blank">-default'>-default'>animation

text=ZqhQzanResources