Security News
UK Officials Consider Banning Ransomware Payments from Public Entities
The UK is proposing a bold ban on ransomware payments by public entities to disrupt cybercrime, protect critical services, and lead global cybersecurity efforts.
react-image-gallery
Advanced tools
react-image-gallery is a flexible and customizable image gallery component for React applications. It allows developers to create responsive and interactive image galleries with features like slide shows, thumbnails, and full-screen mode.
Basic Image Gallery
This code sample demonstrates how to create a basic image gallery using react-image-gallery. The gallery displays a series of images with corresponding thumbnails.
import React from 'react';
import ImageGallery from 'react-image-gallery';
const images = [
{
original: 'https://example.com/image1.jpg',
thumbnail: 'https://example.com/thumb1.jpg',
},
{
original: 'https://example.com/image2.jpg',
thumbnail: 'https://example.com/thumb2.jpg',
},
{
original: 'https://example.com/image3.jpg',
thumbnail: 'https://example.com/thumb3.jpg',
},
];
const MyGallery = () => (
<ImageGallery items={images} />
);
export default MyGallery;
Auto Play Slide Show
This code sample shows how to enable the auto-play feature in the image gallery. The gallery will automatically cycle through the images.
import React from 'react';
import ImageGallery from 'react-image-gallery';
const images = [
{
original: 'https://example.com/image1.jpg',
thumbnail: 'https://example.com/thumb1.jpg',
},
{
original: 'https://example.com/image2.jpg',
thumbnail: 'https://example.com/thumb2.jpg',
},
{
original: 'https://example.com/image3.jpg',
thumbnail: 'https://example.com/thumb3.jpg',
},
];
const MyGallery = () => (
<ImageGallery items={images} autoPlay={true} />
);
export default MyGallery;
Full-Screen Mode
This code sample demonstrates how to enable the full-screen mode in the image gallery. Users can view images in full-screen by clicking the full-screen button.
import React from 'react';
import ImageGallery from 'react-image-gallery';
const images = [
{
original: 'https://example.com/image1.jpg',
thumbnail: 'https://example.com/thumb1.jpg',
},
{
original: 'https://example.com/image2.jpg',
thumbnail: 'https://example.com/thumb2.jpg',
},
{
original: 'https://example.com/image3.jpg',
thumbnail: 'https://example.com/thumb3.jpg',
},
];
const MyGallery = () => (
<ImageGallery items={images} showFullscreenButton={true} />
);
export default MyGallery;
react-photo-gallery is a React component for creating responsive image galleries. It offers a more grid-based layout compared to react-image-gallery and is optimized for performance with features like lazy loading.
react-images is a lightbox component for displaying images in a modal. It focuses on providing a simple and customizable lightbox experience, whereas react-image-gallery offers a more comprehensive gallery solution.
react-slick is a carousel component for React. It is highly customizable and supports various types of content, not just images. It is more versatile in terms of content types compared to react-image-gallery.
React image gallery is a React component for building image gallery and carousels
Features of react-image-gallery
Live demo: linxtion.com/demo/react-image-gallery
npm install react-image-gallery
@import "../node_modules/react-image-gallery/src/image-gallery";
build/image-gallery.css
Need more example? See example/app.js
import ImageGallery from 'react-image-gallery';
class MyComponent extends React.Component {
handleImageLoad(event) {
console.log('Image loaded ', event.target)
}
handlePlay() {
this._imageGallery.play()
}
handlePause() {
this._imageGallery.pause()
}
render() {
const images = [
{
original: 'http://lorempixel.com/1000/600/nature/1/',
thumbnail: 'http://lorempixel.com/250/150/nature/1/',
originalClass: 'featured-slide',
thumbnailClass: 'featured-thumb',
originalAlt: 'original-alt',
thumbnailAlt: 'thumbnail-alt',
description: 'Optional description...'
srcSet: 'Optional srcset (responsive images src)'
size: 'Optional size (image size relative to the breakpoint)'
},
{
original: 'http://lorempixel.com/1000/600/nature/2/',
thumbnail: 'http://lorempixel.com/250/150/nature/2/'
},
{
original: 'http://lorempixel.com/1000/600/nature/3/',
thumbnail: 'http://lorempixel.com/250/150/nature/3/'
}
]
return (
<div>
<button onClick={this.handlePlay.bind(this)}>Play</button>
<button onClick={this.handlePause.bind(this)}>Pause</button>
<ImageGallery
ref={i => this._imageGallery = i}
items={images}
slideInterval={2000}
onImageLoad={this.handleImageLoad}/>
</div>
);
}
}
items
: (required) Array of objects, see example above,infinite
: Boolean, default true
lazyLoad
: Boolean, default false
showNav
: Boolean, default true
showThumbnails
: Boolean, default true
showBullets
: Boolean, default false
showIndex
: Boolean, default false
autoPlay
: Boolean, default false
disableThumbnailScroll
: Boolean, default false
slideOnThumbnailHover
: Boolean, default false
disableArrowKeys
: Boolean, default false
defaultImage
: String, default undefined
onImageError
: Function, callback(event)
onThumbnailError
: Function, callback(event)
indexSeparator
: String, default ' / '
, ignored if showIndex
is falseslideInterval
: Integer, default 3000
startIndex
: Integer, default 0
onImageLoad
: Function, callback(event)
onSlide
: Function, callback(currentIndex)
onPause
: Function, callback(currentIndex)
onPlay
: Function, callback(currentIndex)
onClick
: Function, callback(event)
renderItem
: Function, custom item rendering
[{thumbnail: '...', renderItem: '...'}]
ImageGallery
to completely override _renderItem
, see original below
_renderItem(item) {
const onImageError = this.props.onImageError || this._handleImageError
return (
<div className='image-gallery-image'>
<img
src={item.original}
alt={item.originalAlt}
srcSet={item.srcSet}
sizes={item.sizes}
onLoad={this.props.onImageLoad}
onError={onImageError.bind(this)}
/>
{
item.description &&
<span className='image-gallery-description'>
{item.description}
</span>
}
</div>
)
}
play()
: continuous plays if image is not hoveredpause()
: pauses the slidesfullScreen()
: activates full screenslideToIndex(index)
: slides to a specific indexgetCurrentIndex()
: returns the current indexgit clone https://github.com/xiaolin/react-image-gallery.git
npm install
npm start
Then open localhost:8001
in a browser.
MIT
FAQs
React carousel image gallery component with thumbnail and mobile support
The npm package react-image-gallery receives a total of 110,835 weekly downloads. As such, react-image-gallery popularity was classified as popular.
We found that react-image-gallery demonstrated a not healthy version release cadence and project activity because the last version was released a year ago. It has 1 open source maintainer collaborating on the project.
Did you know?
Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.
Security News
The UK is proposing a bold ban on ransomware payments by public entities to disrupt cybercrime, protect critical services, and lead global cybersecurity efforts.
Security News
Snyk's use of malicious npm packages for research raises ethical concerns, highlighting risks in public deployment, data exfiltration, and unauthorized testing.
Research
Security News
Socket researchers found several malicious npm packages typosquatting Chalk and Chokidar, targeting Node.js developers with kill switches and data theft.