React-Spring:🚀🚀🚀让你的应用栩栩如生

简介: React-Spring:🚀🚀🚀让你的应用栩栩如生

🚀React-Spring是干啥的

React-Spring 是一个用于构建交互式、数据驱动和动画 UI 组件的库。它可以为 HTMLSVGNative ElementsThree.js 等制作动画。

🚀React-Spring优点

  1. 高性能和流畅的动画效果: React-Spring 基于物理动画原理,通过使用 requestAnimationFrameWeb Animations API,以及针对性能进行了优化,可以实现高性能和流畅的动画效果。
  2. 功能丰富:React-Spring 提供了丰富的动画功能,包括弹簧动画、衰减动画、缩放、旋转、平移等效果。它还支持复杂的动画序列和交互式动画,可以创建出各种复杂的动画效果。
  3. 简化的 API: React-Spring 的 API 设计简洁而直观,易于学习和使用。它使用了类似于 React Hooks 的方式来管理动画状态,使得在组件中创建和控制动画变得非常简单。
  4. 与 React 生态系统的良好集成: React-Spring 与 React 框架紧密集成,可以无缝地与其他 React 组件和库一起使用。它可以与 React 的生命周期方法和钩子函数配合使用,使得动画的启动、暂停、结束等操作更加灵活和可控。
  5. 跨平台支持: React-Spring 不仅可以在 Web 应用程序中使用,还可以在移动端应用程序中使用。它支持 React Native,可以在 React Native 项目中创建原生移动端应用的动画效果。

🚀 一些重要的概念

为了更好的掌握,我们在开始之前了解它的几个重要概念

💎 动画元素(Animated Elements)

动画元素是指在 React-Spring 中用于创建动画效果的组件或 DOM 元素。你可以将任何组件或 DOM 元素包装在 animated 函数中,以创建一个动画元素。例如,animated.div 将一个 <div> 元素包装成动画元素。

import { animated } from '@react-spring/web'
// ✅ 正常工作
<animated.div />
// ❌由于mesh不是动画元素,所以这不会工作
<animated.mesh />

💎 useSpring 钩子函数:

useSpringReact-Spring 提供的一个自定义钩子函数,用于创建动画的状态和配置。通过调用 useSpring,你可以定义动画的初始状态和目标状态,以及一些可选的配置参数。useSpring 返回一个包含动画状态和控制方法的对象,你可以将这些状态应用到需要动画的元素上,从而实现动画效果。

import { useSpring, animated } from '@react-spring/web'
export default function MyComponent() {
  const springs = useSpring({
    from: { x: 0 },
    to: { x: 100 },
  })
  return (
    <animated.div
      style={{
        width: 80,
        height: 80,
        background: '#ff6d6d',
        borderRadius: 8,
        ...springs,
      }}
    />
  )
}

你将会看到,当页面刷新时,div元素从左边轻轻划入。

需要说明的是,useSpring 的返回值根据参数的类型不同而不同。

当参数是对象时,返回的是 style 对象,如上。

当参数为函数时,返回的是包含 style 对象和命令 api 接口。如下:

import { useSpring, animated } from '@react-spring/web'
export default function MyComponent() {
  const [springs, api] = useSpring(() => ({
    from: { x: 0 },
  }))
  const handleClick = () => {
    api.start({
      from: {
        x: 0,
      },
      to: {
        x: 100,
      },
    })
  }
  return (
    <animated.div
      onClick={handleClick}
      style={{
        width: 80,
        height: 80,
        background: '#ff6d6d',
        borderRadius: 8,
        ...springs,
      }}
    />
  )
}

好了,我们介绍完了两个基本的概念,那你已经算是入门了,但是,React-Spring 还提供了更多的高级功能。

🚀 其他的一些重要API

💎 useSprings

同时控制多个 useSpring 渲染

import { useSprings, animated } from '@react-spring/web'
export default function MyComponent() {
  const springs = useSprings(12, {
    from: { opacity: 0 },
    to: { opacity: 1 },
  })
  return (
    <div>
      {springs.map(props => (
        <animated.div style={props}>Hello World</animated.div>
      ))}
    </div>
  )
}

💎 轨迹 useTrail

同时控制多个 useSpring 渲染,和 useSprings 不同的是,每个 useSpring 元素会依次展开

import { useTrail, animated } from '@react-spring/web'
export default function MyComponent() {
  const trails = useTrail(12, {
    from: { opacity: 0 },
    to: { opacity: 1 },
  })
  return (
    <div>
      {trails.map(props => (
        <animated.div style={props}>Hello World</animated.div>
      ))}
    </div>
  )
}

💎 控制器 Controller

每个useSpring实际上都是一个Controller。因此,当您使用钩子时,useSpring您会初始化一个新Controller类,并且当您将参数 n 传递给钩子时useSprings,您将创建 n 个数量的Controller

import { useState, useRef } from 'react'
import { Controller, animated } from '@react-spring/web'
function AnimatedComponent() {
  const [isShowing, setIsShowing] = useState(false)
  const animations = useRef(new Controller({ opacity: 0 }))
  const toggle = () => {
    animations.current.start({ opacity: isShowing ? 1 : 0 })
    setIsShowing(!isShowing)
  }
  return (
    <>
      <button onClick={toggle}>click</button>
      <animated.div style={animations.current.springs}>I will fade</animated.div>
    </>
  )
}

💎 调整窗口大小:useResize

自动监听视图窗口大小的改变,适时的做出反应。

import { useResize, animated } from '@react-spring/web'
function MyComponent() {
  const { width, height } = useResize()
  return <animated.div style={{ width, height }}>Hello World</animated.div>
}

💎 监听可视区域:useInView

当元素进入可视区域时,选择动画元素。

import { useInView, animated } from '@react-spring/web'
function MyComponent() {
  const [ref, inView] = useInView()
  return <animated.div ref={ref}>{inView ? 'Hello World' : null}</animated.div>
}

🚀 总结

React-Spring 是一个非常优秀的动画库,它的接口 hook化的设计、常用场景的完美支持,十分贴合react的生态系统,使得它在 Github 斩获了 26.3kstar,所以这是一款值得推荐的库。

🚀 最后

今天的分享就到这了,感谢各位的阅读,文章中如果有纰漏的地方欢迎指正!

相关文章
|
8天前
|
JavaScript 安全 Java
如何使用 Spring Boot 和 Ant Design Pro Vue 实现动态路由和菜单功能,快速搭建前后端分离的应用框架
本文介绍了如何使用 Spring Boot 和 Ant Design Pro Vue 实现动态路由和菜单功能,快速搭建前后端分离的应用框架。首先,确保开发环境已安装必要的工具,然后创建并配置 Spring Boot 项目,包括添加依赖和配置 Spring Security。接着,创建后端 API 和前端项目,配置动态路由和菜单。最后,运行项目并分享实践心得,包括版本兼容性、安全性、性能调优等方面。
62 1
|
19天前
|
Java Maven Docker
gitlab-ci 集成 k3s 部署spring boot 应用
gitlab-ci 集成 k3s 部署spring boot 应用
|
1月前
|
安全 Java 网络安全
当网络安全成为数字生活的守护者:Spring Security,为您的应用筑起坚不可摧的防线
【9月更文挑战第2天】在数字化时代,网络安全至关重要。本文通过在线银行应用案例,详细介绍了Spring Security这一Java核心安全框架的核心功能及其配置方法。从身份验证、授权控制到防御常见攻击,Spring Security提供了全面的解决方案,确保应用安全。通过示例代码展示了如何配置`WebSecurityConfigurerAdapter`及`HttpSecurity`,帮助开发者有效保护应用免受安全威胁。
63 4
|
2月前
|
缓存 Java 数据库连接
Spring Boot奇迹时刻:@PostConstruct注解如何成为应用初始化的关键先生?
【8月更文挑战第29天】作为一名Java开发工程师,我一直对Spring Boot的便捷性和灵活性着迷。本文将深入探讨@PostConstruct注解在Spring Boot中的应用场景,展示其在资源加载、数据初始化及第三方库初始化等方面的作用。
73 0
|
4天前
|
人工智能 开发框架 Java
总计 30 万奖金,Spring AI Alibaba 应用框架挑战赛开赛
Spring AI Alibaba 应用框架挑战赛邀请广大开发者参与开源项目的共建,助力项目快速发展,掌握 AI 应用开发模式。大赛分为《支持 Spring AI Alibaba 应用可视化调试与追踪本地工具》和《基于 Flow 的 AI 编排机制设计与实现》两个赛道,总计 30 万奖金。
|
9天前
|
JavaScript 安全 Java
如何使用 Spring Boot 和 Ant Design Pro Vue 构建一个具有动态路由和菜单功能的前后端分离应用
【10月更文挑战第8天】本文介绍了如何使用 Spring Boot 和 Ant Design Pro Vue 构建一个具有动态路由和菜单功能的前后端分离应用。首先,通过 Spring Initializr 创建并配置 Spring Boot 项目,实现后端 API 和安全配置。接着,使用 Ant Design Pro Vue 脚手架创建前端项目,配置动态路由和菜单,并创建相应的页面组件。最后,通过具体实践心得,分享了版本兼容性、安全性、性能调优等注意事项,帮助读者快速搭建高效且易维护的应用框架。
18 3
|
10天前
|
JavaScript 安全 Java
如何使用 Spring Boot 和 Ant Design Pro Vue 构建一个具有动态路由和菜单功能的前后端分离应用
【10月更文挑战第7天】本文介绍了如何使用 Spring Boot 和 Ant Design Pro Vue 构建一个具有动态路由和菜单功能的前后端分离应用。首先,通过 Spring Initializr 创建 Spring Boot 项目并配置 Spring Security。接着,实现后端 API 以提供菜单数据。在前端部分,使用 Ant Design Pro Vue 脚手架创建项目,并配置动态路由和菜单。最后,启动前后端服务,实现高效、美观且功能强大的应用框架。
13 2
|
14天前
|
人工智能 缓存 Java
深入解析Spring AI框架:在Java应用中实现智能化交互的关键
【10月更文挑战第12天】Spring AI 是 Spring 框架家族的新成员,旨在满足 Java 应用程序对人工智能集成的需求。它支持自然语言处理、图像识别等多种 AI 技术,并提供与云服务(如 OpenAI、Azure Cognitive Services)及本地模型的无缝集成。通过简单的配置和编码,开发者可轻松实现 AI 功能,同时应对模型切换、数据安全及性能优化等挑战。
|
5天前
|
XML Java 数据格式
Spring IOC容器的深度解析及实战应用
【10月更文挑战第14天】在软件工程中,随着系统规模的扩大,对象间的依赖关系变得越来越复杂,这导致了系统的高耦合度,增加了开发和维护的难度。为解决这一问题,Michael Mattson在1996年提出了IOC(Inversion of Control,控制反转)理论,旨在降低对象间的耦合度,提高系统的灵活性和可维护性。Spring框架正是基于这一理论,通过IOC容器实现了对象间的依赖注入和生命周期管理。
15 0
|
1月前
|
Java 对象存储 开发者
故障隔离与容错处理:Hystrix在Spring Cloud和Netflix OSS中的应用
故障隔离与容错处理:Hystrix在Spring Cloud和Netflix OSS中的应用
42 3