React Image Multi is an <img> tag replacement for React.js with preloader and multiple image fallback support.
With React Image Multi you can specify multiple images to be used as fallbacks in the event that the browser couldn't load the previous image. Additionally, you can specify any React element to be used before an image is loaded (i.e. a spinner) and in the event than the specified image(s) could not be loaded.
React Image Multi will cleverly hide "broken" images to prevent showing a the browser default "broken image" placeholder. React Image Multi caches past attempts so that the same image won't be attempted twice.
- To include the code locally in ES6, CommonJS, or UMD format, install
react-img-multiusing npm:
npm install react-img-multi --save
- To include the code globally from a cdn:
<script src="https://unpkg.com/react-img-multi/umd/index.min.js"></script>react-img-multi has no external dependencies, aside for the usual react and react-dom.
Include react-img-multi in your component:
// using an ES6 transpiler, like babel
import Img from 'react-img-multi'
// otherwise
let Img = require('react-img-multi')and set a source for the image:
const myComponent = () => <Img src="www.example.com/foo.jpg">will generate:
<img src="www.example.com/foo.jpg">If the image cannot be loaded, <img> will not be rendered, preventing a "broken" image from showing.
When src is specified as an array, react-img-multi will attempt to load all the images specified in the array, starting at the first and continuing until an image has been successfully loaded.
const myComponent = () =>
<Img src={[
'https://www.example.com/foo.jpg',
'https://www.example.com/bar.jpg'
]}>If an image has previously been attempted unsuccessfully, react-img-multi will not retry loading it again until the page is reloaded.
const myComponent = () =>
<Img
src={[
'https://www.example.com/foo.jpg',
'https://www.example.com/bar.jpg'
]}
loader={/*any valid react element */}
>If an image was previously loaded successfully (since the last time this page was loaded), the loader will not be shown and the image will be rendered directly instead.
const myComponent = () =>
<Img
src={[
'https://www.example.com/foo.jpg',
'https://www.example.com/bar.jpg'
]}
unloader={/*any valid react element */}
>By definition, React Image Multi will try loading images as soon as the <Img> element is rendered in the DOM. This may be undesirable in some situations, such as when the page has many images. As with any react element, rendering can be delayed until the image is actually visible in the viewport using popular libraries such as react-visibility-sensor. Here is a quick sample:
import Img from 'react-img-multi'
import VisibilitySensor from 'react-visibility-sensor'
const myComponent = () =>
<VisibilitySensor>
<Img src='https://www.example.com/foo.jpg'>
</VisibilitySensor>react-img-multi dose not include an Object.assign polyfill, that may be needed depending on your targeted browsers. You can add it in one of the following ways:
-
include it in your package:
https://www.npmjs.com/package/es6-object-assign -
Use Mozilla's polyfill: https://developer.mozilla.org/en/docs/Web/JavaScript/Reference/Global_Objects/Object/assign#Polyfill
-
Include the following code before including
react-img-multi:
Object.assign||function(r){for(var t=1;t<arguments.length;t++){var n=arguments[t];for(var a in n)Object.prototype.hasOwnProperty.call(n,a)&&(r[a]=n[a])}return r};react-img-multi is available under the MIT License