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

前端动画库

网页编辑2个月前 (04-27)修改聊天记录90

// 正确的做法:使用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

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

苹果手机微信分身全解析,一机双号,轻松实现!

苹果手机微信分身全解析,一机双号,轻松实现!

在这个快节奏的时代,微信已成为我们生活中不可或缺的一部分。无论是工作还是生活,微信都扮演着重要的角色。然而,有时我们需要在同一台手机上同时管理两个微信账号,比如一个用于工作,一个用于生活。苹果手机用户常常对此感到困惑:苹果手机是否支持微信分身?能否同时登录两个微信账号?今天,我将和大家分享一些实用的...

以win10系统为例关闭病毒威胁及防火墙

以win10系统为例关闭病毒威胁及防火墙

关闭病毒威胁及防火墙,按下列步骤流程操作。第1步。在桌面点下图“开始”按钮第2步。在向上弹窗点“齿轮”按钮,然后进入控制面板第3步。在控制面板中点“更新和安全”按钮第4步。安全和中心点“病毒和威胁防护”按钮第5步。病毒和威胁防护“管理设置”按钮第6步。管理设置关闭“实时保护”按钮第7步。点左侧的防火...

微信、支付宝、网购订单模拟生成截图软件

微信、支付宝、网购订单模拟生成截图软件

通过简单的设置,可以方便的生成您想要的截图。如微信对话、微信转账、微信红包、微信钱包、微信零钱、支付宝聊天对话、支付宝转账等强大功能 。有了这款软件用户可以随意编辑截图,包括聊天内容,手机壁纸,甚至是转账截图,都可以进行自定义的调整,为大家的生活提供了更多的便利。复制链接到浏览器打开,注册、下载安装...

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

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

苹果iPhone+Mac如何开启WiFi+蓝牙

下面直接给你「一步到位」的极简版,照着点就行(为了隔空投送,**Wi‑Fi 和蓝牙都要开,不需要连同一个 Wi‑Fi 也能投送**)。 --- iPhone 打开 Wi‑Fi + 蓝牙(两种方法) 方法1:控制中心(最快) - 全面屏 iPhone(带刘海):**右上角往下滑**...

发表评论

访客

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