当前位置:首页 > 修改聊天记录 > 正文内容

前端动画库

// 正确的做法:使用Framer Motion

import React from 'react';

import { motion } from 'framer-motion';


function FramerMotionExample() {

  return (

    <div>

      <h2>Framer Motion 示例</h2>

      

      {/* 基础动画 */}

      <motion.div

        initial={{ opacity: 0, y: 20 }}

        animate={{ opacity: 1, y: 0 }}

        transition={{ duration: 0.5 }}

        className="box"

      >

        淡入动画

      </motion.div>

      

      {/* 循环动画 */}

      <motion.div

        animate={{ rotate: 360 }}

        transition={{ duration: 2, repeat: Infinity, ease: "linear" }}

        className="circle"

      >

        旋转动画

      </motion.div>

      

      {/* 交互动画 */}

      <motion.button

        whileHover={{ scale: 1.05 }}

        whileTap={{ scale: 0.95 }}

        className="button"

      >

        悬停按钮

      </motion.button>

      

      {/* 序列动画 */}

      <motion.div className="container">

        {[1, 2, 3, 4, 5].map((item) => (

          <motion.div

            key={item}

            initial={{ opacity: 0, y: 20 }}

            animate={{ opacity: 1, y: 0 }}

            transition={{

              delay: item * 0.1,

              duration: 0.5

            }}

            className="item"

          >

            项目 {item}

          </motion.div>

        ))}

      </motion.div>

    </div>

  );

}


// 正确的做法:使用GSAP

import React, { useEffect, useRef } from 'react';

import gsap from 'gsap';


function GSAPExample() {

  const containerRef = useRef(null);

  const boxRef = useRef(null);

  

  useEffect(() => {

    // 基础动画

    gsap.to(boxRef.current, {

      x: 100,

      y: 50,

      rotate: 45,

      duration: 1,

      ease: "power2.out"

    });

    

    // 时间线动画

    const tl = gsap.timeline({

      repeat: -1,

      yoyo: true

    });

    

    tl.to(".item", {

      x: 100,

      duration: 0.5,

      stagger: 0.1

    })

    .to(".item", {

      y: 50,

      duration: 0.5

    })

    .to(".item", {

      opacity: 0.5,

      duration: 0.5

    });

    

  }, []);

  

  return (

    <div ref={containerRef}>

      <h2>GSAP 示例</h2>

      <div ref={boxRef} className="box">

        GSAP 动画

      </div>

      <div className="container">

        {[1, 2, 3, 4, 5].map((item) => (

          <div key={item} className="item">

            项目 {item}

          </div>

        ))}

      </div>

    </div>

  );

}


// 正确的做法:使用React Spring

import React from 'react';

import { useSpring, animated } from 'react-spring';


function ReactSpringExample() {

  // 基础动画

  const fadeIn = useSpring({

    from: { opacity: 0, transform: 'translateY(20px)' },

    to: { opacity: 1, transform: 'translateY(0)' },

    config: { tension: 100, friction: 10 }

  });

  

  // 交互动画

  const [isHovered, setIsHovered] = React.useState(false);

  const buttonAnimation = useSpring({

    scale: isHovered ? 1.1 : 1,

    config: { tension: 300, friction: 10 }

  });

  

  return (

    <div>

      <h2>React Spring 示例</h2>

      

      <animated.div

        style={fadeIn}

        className="box"

      >

        淡入动画

      </animated.div>

      

      <animated.button

        style={buttonAnimation}

        onMouseEnter={() => setIsHovered(true)}

        onMouseLeave={() => setIsHovered(false)}

        className="button"

      >

        悬停按钮

      </animated.button>

      

      {/* 循环动画 */}

      <animated.div

        style={useSpring({

          rotate: 360,

          from: { rotate: 0 },

          config: { duration: 2000 },

          loop: true

        })}

        className="circle"

      >

        旋转动画

      </animated.div>

    </div>

  );

}


// 正确的做法:选择合适的动画库

function AnimationLibraryComparison() {

  return (

    <div>

      <h1>前端动画库比较</h1>

      

      <div className="comparison">

        <div className="library">

          <h3>CSS Animations</h3>

          <p>优点:简单、性能好、无需依赖</p>

          <p>缺点:复杂动画难以实现、交互性差</p>

          <p>适用场景:简单的过渡效果、加载动画</p>

        </div>

        

        <div className="library">

          <h3>Framer Motion</h3>

          <p>优点:API友好、交互性强、React集成好</p>

          <p>缺点:包体积较大</p>

          <p>适用场景:React应用、复杂交互动画</p>

        </div>

        

        <div className="library">

          <h3>GSAP</h3>

          <p>优点:功能强大、性能优异、支持复杂动画</p>

          <p>缺点:学习曲线较陡</p>

          <p>适用场景:复杂动画、时间线动画、SVG动画</p>

        </div>

        

        <div className="library">

          <h3>React Spring</h3>

          <p>优点:基于物理的动画、性能好、API简洁</p>

          <p>缺点:功能相对较少</p>

          <p>适用场景:流畅的物理动画、交互反馈</p>

        </div>

      </div>

    </div>

  );

}

每种动画库都有其优缺点,你需要根据项目需求和复杂度选择合适的工具。Framer Motion适合React应用,GSAP适合复杂动画,React Spring适合物理动画,CSS适合简单过渡。


所以,别再固守一种动画方式了,灵活选择合适的工具,让你的网站动起来!


总结

CSS Animations:适合简单的过渡效果和加载动画

Framer Motion:适合React应用和复杂交互动画

GSAP:适合复杂动画、时间线动画和SVG动画

React Spring:适合基于物理的流畅动画

性能优化:使用transform和opacity属性,避免重排

动画策略:合理使用动画,避免过度动画

可访问性:考虑动画对用户的影响,提供减少动画的选项

响应式:确保动画在不同设备上都能正常工作

————————————————

版权声明:本文为CSDN博主「大山哥AGI」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。

原文链接:https://blog.csdn.net/cannonmonster01/article/details/159729432


扫描二维码推送至手机访问。

版权声明:本文由手机数据加工厂发布,如需转载请注明出处。

本文链接:https://gaijilu.com/?id=175

“前端动画库” 的相关文章

教您如何将微信聊天记录导出成html等格式

教您如何将微信聊天记录导出成html等格式

可以将微信中的聊天记录(包括文字、图片、语音、表情包甚至拍一拍)导出,方便我们随时分享和查看,此外还有聊天记录分析等有趣的功能,感兴趣的小伙伴可以研究一下。我个人认为导出成htmf是最方便的一种格式,数据导出后点开文件夹中后缀名为.html文件就可以在浏览器中查看所有的聊天记录啦。...

普通版袁大头真假鉴别/手把手教你银元鉴定

普通版袁大头真假鉴别/手把手教你银元鉴定

  一块普通版袁大头行情在800-1500左右,今天我们来看看它的真假鉴别一、银质辨伪:辩别银元的真假,首先从辨识银质的真假开始,银元连银都不是怎么能称为银元呢,从古有“银子发白眼睛发黑”之说,就是说真币越擦越白,晶莹锃亮,表里一致,反之一擦就发黑或灰白,如镀银所制,则有一种浮躁感。二、...

微信的聊天记录能修改吗?能!

微信的聊天记录能修改吗?能!

微信的聊天记录能修改吗?能!能添加、修改。添加的意思是,在原记录中凭空添加自己想要的内容。可以添加在任意位置,自己的名义,对方的名义都可能 。完成后在对话框中展示。与真实发送接受的无异。修改的意思是,原记录的内容可以任意修改,比方说原对话内容是“我爱你”,可以修改为“我不爱你”,“你爱我吗”,内容自...

微信记录彻底备份教程,换手机一键迁移

全程不用复杂操作,老人也能看懂,每一步都对应截图位置。一、手机直接互传(换手机首选,免费最快)适合:旧手机换新手机、当场迁移所有聊天1新旧手机都连上同一个 WiFi,登录同一个微信号2打开微信 → 点【我】→【设置】3找到【通用】→【聊天记录迁移与备份】4选择【迁移聊天记录到另一台设备】5旧手机勾选...

关闭这几个设置,手机瞬间杜绝监听偷窥

1. 关闭多余定位权限所有无关 APP,全部关掉定位只给地图、外卖临时用拒绝 24 小时跟踪你的行踪2. 关闭相机、麦克风权限小游戏、杂牌软件、工具箱全部禁用相机 + 麦克风防止后台偷偷录音、偷拍3. 关闭自动读取剪贴板杜绝 APP 偷看你复制的密码、验证码、聊天内容隐私再也不被偷偷收集4. 关闭后...

手机与电脑如何传递数据

手机+电脑 极简传文件速查表(直接照做,保存备忘录) 一、通用懒人(所有手机+电脑,小文件) 微信/QQ文件传输助手 1. 手机、电脑登录同一账号 2. 互相发送图片、文档、截图 3. 缺点:视频、图片会压缩,大文件慢 二、有线极速(原图/大视频/无压缩,推荐) 安卓 + 电...

发表评论

访客

◎欢迎参与讨论,请在这里发表您的看法和观点。