syncfusion-react-carousel
Implementing the Syncfusion React Carousel Component
Table of Contents
- Overview
- Getting Started
- Populating Items and Selection
- Navigation and Indicators
- Animations and Transitions
- API Properties
- API Methods
- API Events
- Styling and Appearance
- Accessibility
- Image Optimization
- Common Patterns
- Use Cases
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:
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:
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
<CarouselComponent autoPlay={true} showIndicators={true} buttonsVisibility="Visible">
<CarouselItemsDirective>
{/* items */}
</CarouselItemsDirective>
</CarouselComponent>
Pattern 2: Data-Driven Carousel with Dynamic Content
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
const nextButtonTemplate = (props: any): JSX.Element => {
return <ButtonComponent iconCss="e-icons e-chevron-right" />;
}
<CarouselComponent nextButtonTemplate={nextButtonTemplate} />
Pattern 4: Touch-Enabled Mobile Carousel
<CarouselComponent
enableTouchSwipe={true}
swipeMode={CarouselSwipeMode.Touch & CarouselSwipeMode.Mouse}
pauseOnHover={true}
>
{/* items */}
</CarouselComponent>
API Properties Overview
Core Display Properties:
dataSource- Bind carousel to external dataitemTemplate- Template for data-bound itemsitems- Collection of CarouselItemModelselectedIndex- Current slide index
Animation & Behavior:
animationEffect- Animation type (None, Slide, Fade, Custom)interval- Transition delay in milliseconds (default: 5000)autoPlay- Enable auto-play (default: false)loop- Loop slides infinitely (default: true)pauseOnHover- Pause on hover (default: true)enableTouchSwipe- Enable touch swiping (default: true)swipeMode- Touch/mouse swipe modes (Touch, Mouse)
UI Controls:
buttonsVisibility- Navigator buttons (Hidden, Visible, VisibleOnHover)showIndicators- Show indicators (default: true)showPlayButton- Show play/pause button (default: false)indicatorsType- Indicator style (Default, Dynamic, Fraction, Progress)
Customization:
previousButtonTemplate- Previous button UInextButtonTemplate- Next button UIplayButtonTemplate- Play/pause button UIindicatorsTemplate- Indicators UIcssClass- Custom CSS classespartialVisible- Show adjacent slides (default: false)allowKeyboardInteraction- Keyboard navigation (default: true)
Layout & Localization:
height- Component height (pixels/percentage)width- Component width (pixels/percentage)enableRtl- Right-to-left supportenablePersistence- Persist state between reloadslocale- Culture/localization settinghtmlAttributes- 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:
next()- Navigate to next slide with loop supportprev()- Navigate to previous slide with loop supportgetHostElement()- 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:
-
slideChanging- Fires BEFORE transition (cancelable)- Arguments: cancel, currentIndex, currentSlide, nextIndex, nextSlide, isSwiped, name, slideDirection
- Use cases: Validation, confirmation dialogs, preventing access to specific slides
-
slideChanged- 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
More from syncfusion/react-ui-components-skills
syncfusion-react-grid
Implements Syncfusion React Grid component for feature-rich data tables and grids. Use this when working with data display, sorting, filtering, grouping, aggregates, editing, or exporting. This skill covers grid configuration, CRUD operations, virtual scrolling or infinite scrolling, hierarchy grids, state persistence, and advanced data management features for data-intensive applications.
122syncfusion-react-rich-text-editor
Implements the Syncfusion React Rich Text Editor (RichTextEditorComponent) from ej2-react-richtexteditor, supporting HTML (WYSIWYG) and Markdown editing. Use this skill for toolbar configuration, image/video/audio insertion, paste cleanup, AI assistant integration, emoji picker, slash menu, mentions, import/export Word/PDF, form validation, and source code view in React applications.
118syncfusion-react-themes
Use this skill when users need to apply themes, customize appearance, switch dark mode, use CSS variables, configure icons, or modify visual styling for Syncfusion React components. Covers icon library, size modes, and Theme Studio integration.
116syncfusion-react-common
Common utilities and features for Syncfusion React components. Use this skill when the user needs to implement animations, drag-and-drop, state persistence, RTL support, localization, globalization, security, templates, and advanced features for Syncfusion React components.
116syncfusion-react-scheduler
Implement Syncfusion React Scheduler component for calendar, event scheduling, and appointment management. Use this when building scheduling systems, calendar applications, booking systems, or time management interfaces. Covers all scheduler views (Day, Week, Month, Timeline, Agenda, Year), data binding, resource scheduling, recurring events, CRUD operations, drag-and-drop scheduling, customization, accessibility, and advanced features.
116syncfusion-react-treegrid
Implements Syncfusion React TreeGrid for hierarchical data with sorting, filtering, editing, exporting, paging, virtual scrolling, and advanced features. Supports configuration, CRUD, aggregates, templates, state persistence, and performance optimization in React applications.
114