react-useanimations
React-useanimations is a collection of free animated open source icons for React.js.
Top Related Projects
A modern animation library for React and JavaScript
Render After Effects animations natively on Web, Android and iOS, and React Native. http://airbnb.io/lottie/
JavaScript animation engine
GSAP (GreenSock Animation Platform), a JavaScript animation library for the modern web
Animate on scroll library
🍿 A cross-browser library of CSS animations. As easy to use as an easy thing.
Quick Overview
useAnimations/react-useanimations is a React library that provides a collection of animated icons as React components. It offers a simple way to add engaging, interactive animations to web applications using SVG and CSS animations, without the need for heavy JavaScript libraries.
Pros
- Easy to use with a simple API for React applications
- Large collection of pre-made, customizable animated icons
- Lightweight and performant, using SVG and CSS for animations
- Supports TypeScript for improved developer experience
Cons
- Limited to predefined animations, may not suit all custom needs
- Requires React, not suitable for non-React projects
- Some animations may be too complex for certain use cases
- Documentation could be more comprehensive for advanced usage
Code Examples
- Basic usage of an animated icon:
import React from 'react';
import UseAnimations from 'react-useanimations';
import menu2 from 'react-useanimations/lib/menu2';
function App() {
return (
<UseAnimations animation={menu2} size={56} />
);
}
- Using an animated icon with custom color:
import React from 'react';
import UseAnimations from 'react-useanimations';
import github from 'react-useanimations/lib/github';
function App() {
return (
<UseAnimations
animation={github}
size={56}
strokeColor="#000000"
/>
);
}
- Creating a clickable animated icon:
import React, { useState } from 'react';
import UseAnimations from 'react-useanimations';
import heart from 'react-useanimations/lib/heart';
function App() {
const [isLiked, setIsLiked] = useState(false);
return (
<UseAnimations
animation={heart}
size={56}
onClick={() => setIsLiked(!isLiked)}
reverse={isLiked}
/>
);
}
Getting Started
To use react-useanimations in your React project:
-
Install the package:
npm install react-useanimations
-
Import and use the desired animation in your component:
import React from 'react'; import UseAnimations from 'react-useanimations'; import loading from 'react-useanimations/lib/loading'; function MyComponent() { return <UseAnimations animation={loading} />; } export default MyComponent;
-
Customize the animation as needed using props like
size
,strokeColor
,fillColor
,reverse
, andonClick
.
Competitor Comparisons
A modern animation library for React and JavaScript
Pros of Motion
- More comprehensive animation library with a wider range of features
- Better performance optimization for complex animations
- Supports both React and vanilla JavaScript
Cons of Motion
- Steeper learning curve due to more complex API
- Larger bundle size, which may impact load times for smaller projects
Code Comparison
Motion:
import { motion } from "framer-motion"
const Box = () => (
<motion.div
animate={{ x: 100 }}
transition={{ duration: 2 }}
/>
)
React-useAnimations:
import UseAnimations from "react-useanimations"
import menu2 from "react-useanimations/lib/menu2"
const Menu = () => (
<UseAnimations animation={menu2} size={56} />
)
Key Differences
- Motion offers more flexibility and control over animations
- React-useAnimations provides pre-built, ready-to-use animations
- Motion requires more custom code, while React-useAnimations is more plug-and-play
Use Cases
- Motion: Complex, custom animations and interactive UIs
- React-useAnimations: Quick implementation of common UI animations
Community and Support
- Motion has a larger community and more frequent updates
- React-useAnimations is simpler but has fewer resources available
Render After Effects animations natively on Web, Android and iOS, and React Native. http://airbnb.io/lottie/
Pros of lottie-web
- Broader platform support, including Android, iOS, and web
- More mature and widely adopted in the industry
- Extensive documentation and community support
Cons of lottie-web
- Larger file size and potentially higher performance overhead
- Steeper learning curve for complex animations
- Requires external tools for creating animations (e.g., Adobe After Effects)
Code Comparison
react-useanimations:
import UseAnimations from 'react-useanimations';
import menu2 from 'react-useanimations/lib/menu2';
function App() {
return <UseAnimations animation={menu2} />;
}
lottie-web:
import lottie from 'lottie-web';
lottie.loadAnimation({
container: document.getElementById('lottie-container'),
renderer: 'svg',
loop: true,
autoplay: true,
path: 'data.json'
});
react-useanimations offers a more straightforward implementation for React applications, with pre-built animations available as components. lottie-web provides more flexibility and control over animations but requires more setup and configuration. The choice between the two depends on the specific project requirements, target platforms, and desired level of customization.
JavaScript animation engine
Pros of anime
- More versatile, supporting various animation types beyond SVG icons
- Offers greater control over animation timing, easing, and properties
- Can be used with vanilla JavaScript, not limited to React
Cons of anime
- Steeper learning curve due to more complex API
- Requires manual setup for each animation, unlike pre-built icons in react-useanimations
- Larger file size, which may impact performance for simpler projects
Code Comparison
react-useanimations:
import UseAnimations from 'react-useanimations';
import menu2 from 'react-useanimations/lib/menu2';
function App() {
return <UseAnimations animation={menu2} />;
}
anime:
import anime from 'animejs/lib/anime.es.js';
anime({
targets: '.element',
translateX: 250,
rotate: '1turn',
duration: 800,
easing: 'easeInOutQuad'
});
Summary
react-useanimations is ideal for quickly implementing pre-built animated SVG icons in React projects, offering simplicity and ease of use. anime, on the other hand, provides a more powerful and flexible animation library for creating custom animations across various elements and properties. The choice between the two depends on the specific project requirements, complexity of desired animations, and development preferences.
GSAP (GreenSock Animation Platform), a JavaScript animation library for the modern web
Pros of GSAP
- More powerful and flexible animation capabilities
- Extensive documentation and community support
- Cross-browser compatibility and performance optimization
Cons of GSAP
- Steeper learning curve for beginners
- Larger file size and potential impact on page load times
- Requires a license for commercial use in some cases
Code Comparison
GSAP:
import { gsap } from "gsap";
gsap.to(".box", { duration: 1, x: 100, y: 50, rotation: 360 });
react-useAnimations:
import UseAnimations from "react-useanimations";
import menu2 from "react-useanimations/lib/menu2";
<UseAnimations animation={menu2} size={56} />;
Key Differences
- GSAP offers more control over complex animations, while react-useAnimations provides pre-built, easy-to-use animations
- GSAP is framework-agnostic, whereas react-useAnimations is specifically designed for React
- GSAP requires more manual setup and coding, while react-useAnimations focuses on simplicity and quick implementation
Use Cases
- GSAP: Ideal for complex, custom animations and interactive web experiences
- react-useAnimations: Perfect for quickly adding simple, pre-designed animations to React applications
Animate on scroll library
Pros of AOS
- Framework-agnostic, works with any JavaScript project
- Simpler setup and usage, requiring less code to implement
- Offers a wider range of animation options out of the box
Cons of AOS
- Less customizable than React-useAnimations
- Not specifically optimized for React applications
- May have a slightly larger performance impact on complex pages
Code Comparison
AOS:
<div data-aos="fade-up" data-aos-duration="1000">
Animate me!
</div>
React-useAnimations:
import UseAnimations from 'react-useanimations';
import loading from 'react-useanimations/lib/loading';
<UseAnimations animation={loading} size={56} />
AOS focuses on adding animations to HTML elements using data attributes, making it easy to implement across various frameworks. React-useAnimations, on the other hand, provides pre-built animated icons as React components, offering more specific functionality for React applications.
While AOS offers a broader range of animation options and simpler implementation, React-useAnimations provides more customizable and React-specific animated components. The choice between the two depends on the project requirements, with AOS being more versatile across different frameworks and React-useAnimations offering deeper integration with React applications.
🍿 A cross-browser library of CSS animations. As easy to use as an easy thing.
Pros of animate.css
- Lightweight and easy to use with any web project, not limited to React
- Extensive library of pre-built CSS animations
- No JavaScript required, purely CSS-based
Cons of animate.css
- Less control over animation timing and sequencing
- Not optimized for React applications
- Requires manual class manipulation for dynamic animations
Code Comparison
animate.css:
<h1 class="animate__animated animate__bounce">An animated element</h1>
react-useanimations:
import UseAnimations from "react-useanimations";
import menu2 from "react-useanimations/lib/menu2";
<UseAnimations animation={menu2} size={56} />
Key Differences
- react-useanimations is specifically designed for React applications, while animate.css is framework-agnostic
- animate.css provides a wide range of general-purpose animations, whereas react-useanimations focuses on micro-interactions and UI element animations
- react-useanimations offers more programmatic control over animations, making it easier to integrate with React state and props
- animate.css has a larger community and longer history, potentially offering more resources and support
Use Cases
- Choose animate.css for simple, quick animations in any web project
- Opt for react-useanimations when building React applications with complex, interactive UI elements
Convert designs to code with AI
Introducing Visual Copilot: A new AI model to turn Figma designs to high quality code using your components.
Try Visual CopilotREADME
React UseAnimations Icons
What is react-useanimations?
React-useanimations is a collection of free animated open source icons for React.js.
Collection
https://react.useanimations.com and play with examples or visit our Storybook
Installation
Using Yarn:
yarn add react-useanimations
or using NPM:
npm install -S react-useanimations
Usage
If you still need to use v1, please refer to this README instead - react-useanimations@v1
Basic usage
import React from 'react';
import UseAnimations from 'react-useanimations';
// EVERY ANIMATION NEEDS TO BE IMPORTED FIRST -> YOUR BUNDLE WILL INCLUDE ONLY WHAT IT NEEDS
import github from 'react-useanimations/lib/github'
const App = () => <UseAnimations animation={github} />;
export default App;
Icons can be configured with inline props:
<UseAnimations animation={github} size={56} wrapperStyle={{ padding: 100 }} />
These props are available:
Prop | Default | Definition |
---|---|---|
animation | / | animation file |
size | 24 | animation size |
strokeColor | 'inherit' | animation stroke color |
fillColor | '' | animation fill color |
wrapperStyle | {} | wrapper div styles |
pathCss | '' | css string for the animation path element |
reverse | false | assing to true when eg. checkbox should be checked initally |
autoplay | false * | false except in animations like loading etc. |
loop | false * | false except in animations like loading etc. |
options | {} | provide any other custom options which will override the default ones |
speed | 1 | a number to determine the speed of lottie(1 is normal speed) |
Controlled checkbox example
export const RadioButton = () => {
// JUST EXAMPLE - THIS PART OF THE STATE WILL PROBABLY COME FROM A PARENT FORM COMPONENT
const [checked, setChecked] = useState(true);
return (
<div style={{ padding: '20px' }}>
<span>radioButton</span>
<UseAnimation
reverse={checked}
onClick={() => {
setChecked(!checked);
}}
size={40}
wrapperStyle={{ marginTop: '5px' }}
animation={radioButton}
/>
</div>
);
};
Animation wrapped in element (use render prop).
export const WrapperElement = () => {
return (
<UseAnimation
animation={heart}
size={60}
onClick={() => {
// eslint-disable-next-line
console.log('additional onClick cb is working');
}}
render={(eventProps, animationProps) => (
<button style={{ padding: '20px' }} type="button" {...eventProps}>
<div {...animationProps} />
</button>
)}
/>
);
};
Note that eventProps
consists of onClick
, mouseOver
and other DOM events which you probably want to assign to your wrapping element (e.g. Button) and animationProps
consist of an actual animation which you should spread inside a simple <div>
Top Related Projects
A modern animation library for React and JavaScript
Render After Effects animations natively on Web, Android and iOS, and React Native. http://airbnb.io/lottie/
JavaScript animation engine
GSAP (GreenSock Animation Platform), a JavaScript animation library for the modern web
Animate on scroll library
🍿 A cross-browser library of CSS animations. As easy to use as an easy thing.
Convert designs to code with AI
Introducing Visual Copilot: A new AI model to turn Figma designs to high quality code using your components.
Try Visual Copilot