Implementing the Syncfusion React Carousel Component
Table of Contents
The Syncfusion React Carousel component is a powerful, fully-featured carousel for displaying images, content, or any sequential items with automatic or manual transitions. It supports multiple animation effects, customizable indicators and navigators, keyboard navigation, and comprehensive accessibility features.
When to Use This Skill
Implement the Carousel component when you need to:
- Create rotating image galleries with smooth transitions
- Build slideshow presentations with navigation controls
- Display product carousels for e-commerce sites
- Implement testimonial sliders with indicators
- Build content carousels with auto-play functionality
- Support touch/swipe navigation on mobile devices
- Display items with accessibility compliance (WCAG 2.2, Section 508)
Component Overview
The Carousel component manages:
- Visual Display: Renders one active slide with customizable templates
- Navigation: Previous/next buttons with multiple visibility modes
- Indicators: Show current position with multiple indicator types (dots, fractions, progress bars)
- Animations: Smooth slide transitions with fade, slide, or custom effects
- Interaction: Auto-play, manual swipe, keyboard navigation
- Accessibility: Full ARIA support, keyboard shortcuts, screen reader compatibility
Core imports:
ts
import { CarouselComponent, CarouselItemsDirective, CarouselItemDirective } from "@syncfusion/ej2-react-navigations";
Documentation and Navigation Guide
Getting Started
📄 Read: references/getting-started.md
- Installation and package dependencies
- Development environment setup with Vite or Create React App
- CSS imports and theme configuration (Tailwind, Bootstrap, Fluent, Material)
- Basic carousel component setup
- First working example with items
- Common setup issues and solutions
When to read: First time setting up Carousel or troubleshooting initial setup problems.
Populating Items and Selection
📄 Read: references/populating-items.md
- Populating slides using CarouselItem directives
- Data source binding with itemTemplate
- Setting initial slide with selectedIndex
- Navigation with prev() and next() methods
- Partial visible slides (showing adjacent slides)
- Programmatic vs. declarative slide rendering
When to read: Building slide content, handling dynamic data, or implementing navigation controls.
Navigators and Indicators
📄 Read: references/navigators-and-indicators.md
- Previous/next navigator button visibility modes
- Custom navigator button templates
- Showing/hiding indicators (progress dots)
- Four indicator types: Default, Dynamic, Fraction, Progress
- Indicator templates with preview images
- Play/pause button control and templates
When to read: Customizing navigation UI, changing indicator style, or implementing play controls.
Animations and Transitions
📄 Read: references/animations-and-transitions.md
- Animation effects (Fade, Slide, Custom CSS)
- Setting slide transition intervals per item
- Auto-play configuration and timing
- Pause on hover behavior
- Looping and non-looping behavior
- Touch swipe modes and disabled interactions
- Slide changing events (slideChanging, slideChanged)
When to read: Implementing smooth transitions, configuring auto-play, or adding custom animations.
Styling and Appearance
📄 Read: references/styling-and-appearance.md
- CSS class structure for customization
- Customizing indicator appearance and spacing
- Navigator button positioning and styling
- Partial slide area customization
- Theme Studio integration for visual theming
- Dark mode and custom color schemes
When to read: Styling indicators/navigators, positioning elements, or creating custom themes.
Accessibility
📄 Read: references/accessibility.md
- WCAG 2.2 and Section 508 compliance
- ARIA attributes and roles
- Keyboard interaction shortcuts (arrows, Home, End, Space, Enter)
- Screen reader support
- Focus management and mobile accessibility
When to read: Building accessible carousels or implementing keyboard navigation.
Image Optimization
📄 Read: references/image-optimization.md
- Loading carousel images in WebP format
- Performance benefits and file size reduction
- Image format conversion techniques
- Implementation with carousel items
When to read: Optimizing carousel performance or implementing modern image formats.
Quick Start Example
Minimal working carousel with 5 images:
tsx
import { CarouselComponent, CarouselItemsDirective, CarouselItemDirective } from "@syncfusion/ej2-react-navigations";
import * as React from "react";
const App = () => {
return (
<div className='control-container'>
<CarouselComponent>
<CarouselItemsDirective>
<CarouselItemDirective template='<figure class="img-container"><img src="url" alt="cardinal" style="height:100%;width:100%;" /><figcaption class="img-caption">Cardinal</figcaption></figure>' />
<CarouselItemDirective template='<figure class="img-container"><img src="url" alt="kingfisher" style="height:100%;width:100%;" /><figcaption class="img-caption">Kingfisher</figcaption></figure>' />
<CarouselItemDirective template='<figure class="img-container"><img src="url" alt="toucan" style="height:100%;width:100%;" /><figcaption class="img-caption">Toucan</figcaption></figure>' />
<CarouselItemDirective template='<figure class="img-container"><img src="url" alt="warbler" style="height:100%;width:100%;" /><figcaption class="img-caption">Warbler</figcaption></figure>' />
<CarouselItemDirective template='<figure class="img-container"><img src="url" alt="bee-eater" style="height:100%;width:100%;" /><figcaption class="img-caption">Bee-eater</figcaption></figure>' />
</CarouselItemsDirective>
</CarouselComponent>
</div>
);
}
export default App;
Common Patterns
Pattern 1: Auto-Play Gallery with Indicators and Navigators
tsx
<CarouselComponent autoPlay={true} showIndicators={true} buttonsVisibility="Visible">
<CarouselItemsDirective>
{/* items */}
</CarouselItemsDirective>
</CarouselComponent>
Pattern 2: Data-Driven Carousel with Dynamic Content
tsx
const itemTemplate = (props: any): JSX.Element => {
return <img src={props.imageUrl} alt={props.title} />;
}
<CarouselComponent dataSource={carouselData} itemTemplate={itemTemplate} />
Pattern 3: Carousel with Custom Navigation Buttons
tsx
const nextButtonTemplate = (props: any): JSX.Element => {
return <ButtonComponent iconCss="e-icons e-chevron-right" />;
}
<CarouselComponent nextButtonTemplate={nextButtonTemplate} />
Pattern 4: Touch-Enabled Mobile Carousel
tsx
<CarouselComponent
enableTouchSwipe={true}
swipeMode={CarouselSwipeMode.Touch & CarouselSwipeMode.Mouse}
pauseOnHover={true}
>
{/* items */}
</CarouselComponent>
API Properties Overview
Core Display Properties:
- - Bind carousel to external data
- - Template for data-bound items
- - Collection of CarouselItemModel
- - Current slide index
Animation & Behavior:
- - Animation type (None, Slide, Fade, Custom)
- - Transition delay in milliseconds (default: 5000)
- - Enable auto-play (default: false)
- - Loop slides infinitely (default: true)
- - Pause on hover (default: true)
- - Enable touch swiping (default: true)
- - Touch/mouse swipe modes (Touch, Mouse)
UI Controls:
- - Navigator buttons (Hidden, Visible, VisibleOnHover)
- - Show indicators (default: true)
- - Show play/pause button (default: false)
- - Indicator style (Default, Dynamic, Fraction, Progress)
Customization:
- - Previous button UI
- - Next button UI
- - Play/pause button UI
- - Indicators UI
- - Custom CSS classes
- - Show adjacent slides (default: false)
- - Keyboard navigation (default: true)
Layout & Localization:
- - Component height (pixels/percentage)
- - Component width (pixels/percentage)
- - Right-to-left support
- - Persist state between reloads
- - Culture/localization setting
- - Custom HTML attributes
Common Use Cases
1. Product Gallery (E-Commerce)
- Display product images with fade animation
- Show indicators to indicate available images
- Enable swipe for mobile users
- See: populating-items.md + animations-and-transitions.md
2. Testimonial/Review Carousel
- Auto-play testimonials with 10-second intervals
- Custom testimonial template
- Pause on hover to allow reading
- See: populating-items.md + animations-and-transitions.md
3. Accessible Banner Carousel
- Keyboard navigation with Home/End/Arrow keys
- WCAG 2.2 compliant structure
- Screen reader friendly labels
- See: accessibility.md
4. Styled Hero Carousel
- Custom navigator and indicator styling
- Partial visible slides for context
- Theme Studio customization
- See: styling-and-appearance.md + navigators-and-indicators.md
5. Data-Bound Carousel
- Bind carousel to REST API data
- Dynamic templates based on item properties
- Real-time updates
- See: populating-items.md
Complete API Reference
API Properties Reference
📄 Read: references/api-properties.md
Comprehensive documentation for all 28+ carousel properties organized by functionality:
- Core Data & Selection: dataSource, itemTemplate, items, selectedIndex
- Animation & Timing: animationEffect, interval, autoPlay, loop, pauseOnHover
- Navigation & Indicators: buttonsVisibility, showIndicators, indicatorsType, showPlayButton
- Template & Customization: Button/indicator templates, cssClass, partialVisible
- Interaction & Accessibility: enableTouchSwipe, swipeMode, allowKeyboardInteraction
- Layout & Localization: height, width, enableRtl, enablePersistence, locale, htmlAttributes
Each property includes type information, default values, and practical code examples.
API Methods Reference
📄 Read: references/api-methods.md
Complete documentation for all carousel control methods:
- - Navigate to next slide with loop support
- - Navigate to previous slide with loop support
- - Access underlying carousel DOM element
Includes method signatures, use cases, practical examples, and advanced patterns like skip multiple slides, go to specific slide, and scroll-to-carousel functionality.
API Events Reference
📄 Read: references/api-events.md
Comprehensive event documentation with complete event arguments:
-
- Fires BEFORE transition (cancelable)
- Arguments: cancel, currentIndex, currentSlide, nextIndex, nextSlide, isSwiped, name, slideDirection
- Use cases: Validation, confirmation dialogs, preventing access to specific slides
-
- Fires AFTER transition (not cancelable)
- Arguments: currentIndex, currentSlide, previousIndex, previousSlide, isSwiped, name, slideDirection
- Use cases: Analytics tracking, updating UI counters, loading content, triggering animations
Includes practical examples for rate limiting, history tracking, analytics integration, and event pattern library.
Next Steps
- Start here: Read getting-started.md to install and configure
- Add content: Follow populating-items.md for your data
- Customize UI: Use navigators-and-indicators.md for controls
- Enhance behavior: Reference animations-and-transitions.md for effects
- Polish design: Apply styling-and-appearance.md for styling
- Ensure access: Implement accessibility.md for compliance
- Optimize images: Use image-optimization.md for performance