Description
9 awesome typescript-aware lightweight spinners built as react.js components.
spinners-react alternatives and similar libraries
Based on the "Loader" category.
Alternatively, view spinners-react alternatives based on common mentions on social networks and blogs.
-
react-content-loader
⚪ SVG-Powered component to easily create skeleton loadings. -
react-spinners
A collection of loading spinner components for react -
react-spinkit
A collection of loading indicators animated with CSS for React -
react-redux-loading-bar
Loading Bar (aka Progress Bar) for Redux and React -
react-loader-spinner
Collection sets of a spinners for async operations for ReactJS -
react-loader
React component that displays a spinner via spin.js until your component is loaded. -
react-progress-button
:cyclone: Simple react.js component for an inline progress indicator -
react-block-ui
Easy way to block the user from interacting with your UI. -
react-spinners-css
Amazing collection of React spinners components with pure css -
react-md-spinner
Material Design spinner components for React.js. -
react-progress-label
Progress component for React and React Native -
React Nested Loader
The easiest way to inject a loader into a deeply nested component
Appwrite - The Open Source Firebase alternative introduces iOS support
Do you think we are missing an alternative of spinners-react or a related project?
README
Spinners React
9 awesome typescript-aware lightweight spinners built as react.js components.
Demo
View demo with examples of react.js component usage.
Getting started
Installation
$ npm install spinners-react
or add it directly to HTML page
Usage
import { SpinnerCircular } from 'spinners-react';
<SpinnerCircular />
Hide spinner
<SpinnerCircular enabled={false} />
List of components
Component | Example | Component | Example | Component | Example |
---|---|---|---|---|---|
SpinnerCircular |
SpinnerCircularFixed |
SpinnerCircularSplit |
|||
SpinnerRound |
SpinnerRoundOutlined |
SpinnerRoundFilled |
|||
SpinnerDotted |
SpinnerInfinity |
SpinnerDiamond |
Properties
The following optional properties are available. All extra props will be passed to the component's root SVG element.
Property | Default value | Type | Description |
---|---|---|---|
size | 50 |
number or string | Set the size as number of pixels or any valid CSS string (e.g. size="100%" ). |
thickness | 100 |
number | Set lines width as a percentage of default thickness. |
сolor | '#38ad48' |
string | Set the color. Can be set to any valid CSS string (hex, rgb, rgba). |
secondaryColor | 'rgba(0,0,0,0.44)' |
string | Set the secondary color. Can be set to any valid CSS string (hex, rgb, rgba). |
speed | 100 |
number | Set the animation speed as a percentage of default speed. |
enabled | true |
boolean | Show/Hide the spinner. |
still | false |
boolean | Disable/Enable spinner animation. |
style | undefined | object | Pass CSS styles to the root SVG element |
Server Side Rendering
While the library works with SSR, the spinner's animation CSS will be attached to the head only on the hydrate
phase, which means the spinners will start animating only after the page is fully loaded. To work around this, include the needed css in your bundle.css manually:
/* App.css */
/* to load animation for a specific spinner */
@import "~spinners-react/lib/SpinnerCircular.css";
/* to load animations for all spinners at once */
@import "~spinners-react/lib/index.css";
Minimizing Bundle Size
The library is thin and do not rely on any style library / runtime to be used. To reduce the bundle size even more load only the used components. If you're using ES6 modules and a bundler that supports tree-shaking you can safely use named imports:
import { SpinnerCircular } from 'spinners-react';
It that's not the case you're able to use path imports to avoid pulling in unused spinners:
// ESM
import { SpinnerCircular } from 'spinners-react/lib/esm/SpinnerCircular';
// or CJS
const { SpinnerCircular } = require('spinners-react/lib/cjs/SpinnerCircular');
// or UMD
const { SpinnerCircular } = require('spinners-react/lib/cjs/SpinnerCircular');
UMD bundle usage
<!doctype html>
<html>
<head>
<script src="https://unpkg.com/[email protected]/umd/react.production.min.js"></script>
<script src="https://unpkg.com/[email protected]/umd/react-dom.production.min.js"></script>
<!-- to load a specific spinner -->
<script src="https://unpkg.com/spinners-react/lib/umd/SpinnerCircular.min.js"></script>
<!-- to load all spinners at once -->
<script src="https://unpkg.com/spinners-react/lib/umd/index.min.js"></script>
</head>
<body>
<div id="root"></div>
<script>
ReactDOM.render(
React.createElement(SpinnersReact.SpinnerCircular),
document.getElementById('root')
);
</script>
</body>
</html>
Browsers support
Firefox | Chrome | Safari | Opera | Edge |
---|---|---|---|---|
last 2 versions | last 2 versions | last 2 versions | last 2 versions | last 2 versions* |
* - Legacy EdgeHTML Edge (i.e. 42-44) is also supported except for SpinnerRound
and SpinnerRoundOutlined
.
Issues and Bugs
Let us know if you found a bug!
Spinners for other frameworks
Support and Contact
Have a quick question or need some help? Please do not hesitate to contact us via email at [email protected].
Credits
This component is developed by consulting agency Adexin.
License
Spinners React is released under MIT license. You are free to use, modify and distribute this software, as long as the copyright header is left intact.
*Note that all licence references and agreements mentioned in the spinners-react README section above
are relevant to that project's source code only.