在React中实现CSS动画的回放

1. 使用key属性强制组件重载

React组件:

javascript 复制代码
import "./styles.css";
import React, { useState } from "react";

export default function App() {
  const [key, setKey] = useState(0);

  const replay = () => {
    setKey((prevKey) => prevKey + 1); // 改变key,触发组件重新渲染
  };

  return (
    <div className="App">
      <div key={key} className="animated-element">
        内容
      </div>
      <button onClick={replay}>重播</button>
    </div>
  );
}

CSS动画:

css 复制代码
.App {
  font-family: sans-serif;
  text-align: center;
}

.animated-element {
  animation: fadeIn 1s ease-in-out;
}

@keyframes fadeIn {
  from {
    opacity: 0;
    transform: translateY(-20px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

缺点是会导致组件完全重新挂载,可能影响性能。

2.通过重置类名触发动画重播

React组件:

javascript 复制代码
import "./styles.css";
import React, { useState } from "react";

export default function App() {
  const [isAnimating, setIsAnimating] = useState(true);

  const replay = () => {
    // 1. 先移除动画类
    setIsAnimating(false);
    // 2. 在下一帧重新添加,触发动画重播
    requestAnimationFrame(() => {
      setIsAnimating(true);
    });
  };

  return (
    <div className="App">
      <div className={`${isAnimating ? "animated-element" : ""}`}>内容</div>
      <button onClick={replay}>重播</button>
    </div>
  );
}

CSS动画同上。

这种方式需要注意的是toggle类名的时候要在下一帧重新添加,否则会被React合并导致不生效。优点是简单直接,性能好。对于大多数简单场景,重置类名是性能和复杂度平衡的最佳选择。

动画回放演示

相关推荐
漂流瓶jz7 小时前
Webpack如何实现万物皆可import?loader的使用/配置/手写实践
前端·javascript·webpack
ZC跨境爬虫7 小时前
跟着 MDN 学CSS day_41:显式轨道、隐式网格与区域命名放置
前端·javascript·css·ui·交互
weelinking7 小时前
【产品】12_接入数据库——让数据永久保存
jvm·数据库·python·react.js·数据挖掘·前端框架·产品经理
修己xj8 小时前
告别手动存图!这款叫 Fatkun 的浏览器插件,简直是素材收集神器
前端
袋鼠云数栈9 小时前
从前端到基础设施,ACOS 如何打通企业全链路可观测
运维·前端·人工智能·数据治理·数据智能
AskHarries9 小时前
系统提示词、开发者指令和用户输入的优先级
java·前端·数据库
Moment9 小时前
长上下文会最终杀死 Rag 吗?
前端·javascript·后端
qcx239 小时前
【系统学AI】25 论文导读 ①:两篇改变 AI 的开山之作——Attention Is All You Need & ReAct
前端·人工智能·react.js·transformer
kyriewen10 小时前
大文件上传最全指南:分片、断点续传、秒传,一篇就够了
前端·javascript·面试
郑洁文11 小时前
基于Python的Web命令执行漏洞自动化检测系统
前端·python·网络安全·自动化