React
BoxSlider React components are a thin wrapper around the Web Components for each slide effect and the slider controls.
Installation
npm i --save @boxslider/react@latest
Components
Each slide effect has a matching React component. The options for the slider and the effect are passed as props. View the configuration options for the available options.
// Example prop types
<CarouselSlider speed={500} timingFunction="ease-in" cover>{children}</CarouselSlider>
<CubeSlider />
<FadeSlider />
<TileSlider />
The slider components do not have any controls built in. Use the SliderControls
component to add navigation
controls to the slider. See the slider controls guide for more information.
<SliderControls>
<CarouselSlider>
<div>Slide one</div>
<div>Slide two</div>
<div>Slide three</div>
</CarouselSlider>
</SliderControls>
Styling
The components do not include any styles by default. The display, width and height style properties need to be set as a minimum for the slider to work. View the styling guide for more information on how to effectively style the slider components.
const sliderStyles = {
display: 'block',
height: '400px',
width: '800px'
}
const slideStyles = {
height: '100%',
width: '100%'
}
<CarouselSlider style={sliderStyles}>
<div style={slideStyles}>Slide 1</div>
<div style={slideStyles}>Slide 2</div>
<div style={slideStyles}>Slide 3</div>
</CarouselSlider>
Events
Handlers for slider events can be provided in props with the
naming convention on<EventName>
.
function MySlider({ children }) {
const handlePause = () => console.log('Slider paused')
return <FadeSlider onPause={handlePause}>{children}</FadeSlider>
}
sliderRef
prop
To gain access to the BoxSlider instance pass a ref to the sliderRef
props. The current value
of the ref will be set once the component is mounted and the slider instance is initialised. View
the API reference for more information on the available methods.
function Slider() {
const sliderRef = useRef(null)
return (
<div>
<CarouselSlider sliderRef={sliderRef}>
<div>Slide one</div>
<div>Slide two</div>
<div>Slide three</div>
<div>Slide four</div>
<div>Slide five</div>
</CarouselSlider>
<button onClick={() => sliderRef.current?.prev()}>Previous slide</button>
<button onClick={() => sliderRef.current?.next()}>Next slide</button>
</div>
)
}