http://leandrowd.github.io/react-responsive-carousel/
Check it out these cool demos created using storybook. The source code for each example is available here
npm install react-responsive-carousel --save
var React = require('react');
var ReactDOM = require('react-dom');
var Carousel = require('react-responsive-carousel').Carousel;
var DemoCarousel = React.createClass({
render() {
return (
<Carousel axis="horizontal|vertical" showThumbs={true|false} showArrows={true|false} onChange={onChange} onClickItem={onClickItem} onClickThumb={onClickThumb}>
<div>
<img src="assets/1.jpeg" />
<p className="legend">Legend 1</p>
</div>
<div>
<img src="assets/2.jpeg" />
<p className="legend">Legend 2</p>
</div>
<div>
<img src="assets/3.jpeg" />
<p className="legend">Legend 3</p>
</div>
</Carousel>
);
}
});
ReactDOM.render(<DemoCarousel />, document.querySelector('.demo-carousel'));
// Don't forget to include the css in your page
// <link rel="stylesheet" href="carousel.css"/>| Attributes | Type | Default | Description |
|---|---|---|---|
| showArrows | boolean |
true |
show prev and next arrows |
| showStatus | boolean |
true |
show index of the current item. i.e: (1/8) |
| showIndicators | boolean |
true |
show little dots at the bottom with links for changing the item |
| showThumbs | boolean |
true |
show thumbnails of the images |
| infiniteLoop | boolean |
false |
infinite loop sliding |
| selectedItem | number |
0 |
selects an item though props / defines the initial selected item |
| axis | string |
horizontal |
changes orientation - accepts horizontal and vertical |
| onChange | function |
- | Fired when changing positions |
| onClickItem | function |
- | Fired when an item is clicked |
| onClickThumb | function |
- | Fired when a thumb it clicked |
| width | string |
- | Allows to set a fixed width |
| useKeyboardArrows | boolean |
false | Adds support to next and prev through keyboard arrows |
=======================
Feel free to submit a PR or raise issues. When submitting a PR, please:
- add the required tests and an example of usage to
stories/index.js - don't submit changes to the
/libfolder as it will be generated again after the merge. - ensure you have the editorConfig plugin or the same code style settings as defined in
.editorConfigto avoid excess of spaces in diffs
=======================
git clone [email protected]:leandrowd/react-responsive-carousel.gitnpm installnpm start- Open your favourite browser on
localhost:8000- livereload will be enabled and tests will run on each change
The fastest dev environment is on node 6. If you have
nvminstalled, just runnvm use 6. Tests in travis will run on node 4 and 6
npm test
npm run storybook
=======================
npm run publish-to-npm
npm run publish-to-gh-pages
=======================
https://github.com/leandrowd/demo-react-responsive-carousel-es6