emg
A simple, enhanced react image component with loading spinner, fallback support and others.
Examples
see the examples
Features
- lazy loading
- loading indicator
- error handler and fallback placeholder
Installing
Using command line:
$ yarn add emg
$ npm i -S emg
Using cdn:
<script src="//unpkg.com/emg/dist/emg.umd.js"></script>
Usage
import Emg as Img from 'emg';
class Example extends React.Component{
public render(){
return <Img src="url/for/image"/>
}
}
Options
- className: class name
- src: url of the image to load
- alt: alt for the image
- title: title attribute for the image
- style: inline style for the image
- type:
React.CSSProperties
- loadingImg: show while image loading
- loadErrImg: show when failed to load the image
- fallbackImg: instead of showing an error image, show this fallback one
- isLazyLoad: whether lazy load or not. enable only when
IntersectionObserver
is supported
- type:
boolean
- default:
false
- onLoad:
onload
handler
- type:
(event: Event) => void
- onError:
onerror
handler
- type:
(event: Event) => void
Development
For development, clone this repo then
$ yarn install && yarn start
this will start a local server then open browser and go to http://localhost:3000
to see examples in action.
available scripts:
build
: generate budnles that are ready to publishdev
: start local server for local developmentlint
: run tslint & stylelint
TODO
Acknowledgement
Lazy load
Lazy load using the modern IntersectionObserver
api.
For more info you can read
Lazy Loading Images and Video from WebFundamentals.