react-loadermixin
v1.0.4
Published
A React mixin for giving components loading behavior
Downloads
485
Readme
react-loadermixin
A component that is a loader is expected to meet the following contract:
- It accepts
src
,onLoad
, andonError
props - It calls
onLoad
when it successfully loads thesrc
- It calls
onError
if it fails to load thesrc
This simple React mixin helps a component meet that contract.
Usage
var LoaderMixin = require('react-loadermixin');
// Create a component that mixes in the loader behaviors. The class can take
// advantage of a few useful features of the mixin: It can define
// `loaderDidLoad` and `loaderDidError` hooks, and it can use the provided
// `renderLoader()` method to call a loader function with the `src` prop and
// bind to the `onLoad` and `onError` events of the loader function.
var LoaderComponent = React.createClass({
mixins: [LoaderMixin],
loaderDidLoad: function() {
// Do something on load.
},
loaderDidError: function(error) {
// Do something on error.
},
render: function() {
// For illustration, we use an img component as our loader function. It's a
// good choice because it implements The expected interface for a loader
// function in that it takes `src`, `onLoad`, and `onError` props.
this.renderLoader(React.DOM.img, {className: 'image'});
}
});
// ...in a parent component's `render()`.
<LoaderComponent
src="/path/to/image.jpg"
onLoad={this.handleLoad}
onError={this.handleError}
/>
Props
These props are accepted by the component and used by the mixin throughout the load cycle.
Component Specifications
These methods are provided to the component class by the mixin.
Load cycle methods
These methods may optionally be defined on the component class. If they are defined, the mixed in behavior will utilize them at particular points throughout the load cycle.