2014-07-12 11:20:15 +02:00
---
2015-08-15 07:45:55 +02:00
layout: docs
2014-07-12 11:20:15 +02:00
title: Carousel
2016-10-03 03:19:47 +02:00
description: A slideshow component for cycling through elements—images or slides of text—like a carousel.
2015-08-06 02:47:45 +02:00
group: components
2014-07-12 11:20:15 +02:00
---
2015-10-12 00:20:12 +02:00
A slideshow component for cycling through elements—images or slides of text—like a carousel. In browsers where the [Page Visibility API ](http://www.w3.org/TR/page-visibility/ ) is supported, the carousel will avoid sliding when the webpage is not visible to the user (such as when the browser tab is inactive, the browser window is minimized, etc.). **Nested carousels are not supported.**
2014-07-13 09:54:14 +02:00
2015-05-29 10:58:52 +02:00
## Contents
* Will be replaced with the ToC, excluding the "Contents" header
{:toc}
2014-09-18 00:21:31 +02:00
## Example
2014-07-13 09:54:14 +02:00
{% example html %}
2014-03-17 03:03:53 +01:00
< div id = "carousel-example-generic" class = "carousel slide" data-ride = "carousel" >
< ol class = "carousel-indicators" >
< li data-target = "#carousel-example-generic" data-slide-to = "0" class = "active" > < / li >
< li data-target = "#carousel-example-generic" data-slide-to = "1" > < / li >
< li data-target = "#carousel-example-generic" data-slide-to = "2" > < / li >
< / ol >
2014-07-08 04:53:57 +02:00
< div class = "carousel-inner" role = "listbox" >
2014-12-18 03:30:16 +01:00
< div class = "carousel-item active" >
2014-07-13 09:54:14 +02:00
< img data-src = "holder.js/900x500/auto/#777:#555/text:First slide" alt = "First slide" >
2014-03-17 03:03:53 +01:00
< / div >
2014-12-18 03:30:16 +01:00
< div class = "carousel-item" >
2014-07-13 09:54:14 +02:00
< img data-src = "holder.js/900x500/auto/#666:#444/text:Second slide" alt = "Second slide" >
< / div >
2014-12-18 03:30:16 +01:00
< div class = "carousel-item" >
2014-07-13 09:54:14 +02:00
< img data-src = "holder.js/900x500/auto/#555:#333/text:Third slide" alt = "Third slide" >
2014-04-01 22:03:14 +02:00
< / div >
2014-03-17 03:03:53 +01:00
< / div >
2014-05-10 00:31:52 +02:00
< a class = "left carousel-control" href = "#carousel-example-generic" role = "button" data-slide = "prev" >
2014-12-01 05:17:45 +01:00
< span class = "icon-prev" aria-hidden = "true" > < / span >
2014-07-08 05:04:22 +02:00
< span class = "sr-only" > Previous< / span >
2014-03-17 03:03:53 +01:00
< / a >
2014-05-10 00:31:52 +02:00
< a class = "right carousel-control" href = "#carousel-example-generic" role = "button" data-slide = "next" >
2014-12-01 05:17:45 +01:00
< span class = "icon-next" aria-hidden = "true" > < / span >
2014-07-08 05:04:22 +02:00
< span class = "sr-only" > Next< / span >
2014-03-17 03:03:53 +01:00
< / a >
< / div >
2014-07-13 09:54:14 +02:00
{% endexample %}
2014-03-17 03:03:53 +01:00
2015-04-17 01:56:40 +02:00
{% callout warning %}
#### Transition animations not supported in Internet Explorer 9
2014-03-17 03:03:53 +01:00
2015-04-17 01:56:40 +02:00
Bootstrap exclusively uses CSS3 for its animations, but Internet Explorer 9 doesn't support the necessary CSS properties. Thus, there are no slide transition animations when using that browser. We have intentionally decided not to include jQuery-based fallbacks for the transitions.
{% endcallout %}
{% callout warning %}
#### Initial active element required
The `.active` class needs to be added to one of the slides. Otherwise, the carousel will not be visible.
{% endcallout %}
2014-12-01 05:17:45 +01:00
2014-07-13 09:54:14 +02:00
### Optional captions
2014-12-18 03:30:16 +01:00
Add captions to your slides easily with the `.carousel-caption` element within any `.carousel-item` . Place just about any optional HTML within there and it will be automatically aligned and formatted.
2014-07-13 09:54:14 +02:00
2015-04-16 23:07:20 +02:00
< div class = "bd-example" >
2014-07-13 09:54:14 +02:00
< div id = "carousel-example-captions" class = "carousel slide" data-ride = "carousel" >
< ol class = "carousel-indicators" >
< li data-target = "#carousel-example-captions" data-slide-to = "0" class = "active" > < / li >
< li data-target = "#carousel-example-captions" data-slide-to = "1" > < / li >
< li data-target = "#carousel-example-captions" data-slide-to = "2" > < / li >
< / ol >
< div class = "carousel-inner" role = "listbox" >
2014-12-18 03:30:16 +01:00
< div class = "carousel-item active" >
2014-07-13 09:54:14 +02:00
< img data-src = "holder.js/900x500/auto/#777:#777" alt = "First slide image" >
< div class = "carousel-caption" >
< h3 > First slide label< / h3 >
< p > Nulla vitae elit libero, a pharetra augue mollis interdum.< / p >
2014-03-17 03:03:53 +01:00
< / div >
2014-07-13 09:54:14 +02:00
< / div >
2014-12-18 03:30:16 +01:00
< div class = "carousel-item" >
2014-07-13 09:54:14 +02:00
< img data-src = "holder.js/900x500/auto/#666:#666" alt = "Second slide image" >
< div class = "carousel-caption" >
< h3 > Second slide label< / h3 >
< p > Lorem ipsum dolor sit amet, consectetur adipiscing elit.< / p >
2014-03-17 03:03:53 +01:00
< / div >
2014-07-13 09:54:14 +02:00
< / div >
2014-12-18 03:30:16 +01:00
< div class = "carousel-item" >
2015-06-19 08:56:43 +02:00
< img data-src = "holder.js/900x500/auto/#555:#555" alt = "Third slide image" >
2014-07-13 09:54:14 +02:00
< div class = "carousel-caption" >
< h3 > Third slide label< / h3 >
< p > Praesent commodo cursus magna, vel scelerisque nisl consectetur.< / p >
2014-03-17 03:03:53 +01:00
< / div >
< / div >
< / div >
2014-07-13 09:54:14 +02:00
< a class = "left carousel-control" href = "#carousel-example-captions" role = "button" data-slide = "prev" >
2014-12-01 05:17:45 +01:00
< span class = "icon-prev" aria-hidden = "true" > < / span >
2014-07-13 09:54:14 +02:00
< span class = "sr-only" > Previous< / span >
< / a >
< a class = "right carousel-control" href = "#carousel-example-captions" role = "button" data-slide = "next" >
2014-12-01 05:17:45 +01:00
< span class = "icon-next" aria-hidden = "true" > < / span >
2014-07-13 09:54:14 +02:00
< span class = "sr-only" > Next< / span >
< / a >
< / div >
< / div >
2014-03-17 03:03:53 +01:00
{% highlight html %}
2014-12-18 03:30:16 +01:00
< div class = "carousel-item" >
2014-03-17 03:03:53 +01:00
< img src = "..." alt = "..." >
< div class = "carousel-caption" >
< h3 > ...< / h3 >
< p > ...< / p >
< / div >
< / div >
{% endhighlight %}
2015-04-17 01:56:40 +02:00
{% callout danger %}
#### Accessibility issue
The carousel component is generally not compliant with accessibility standards. If you need to be compliant, please consider other options for presenting your content.
{% endcallout %}
2014-07-13 09:54:14 +02:00
## Usage
2014-12-19 00:30:34 +01:00
### Multiple carousels
2014-03-17 03:03:53 +01:00
2014-07-13 09:54:14 +02:00
Carousels require the use of an `id` on the outermost container (the `.carousel` ) for carousel controls to function properly. When adding multiple carousels, or when changing a carousel's `id` , be sure to update the relevant controls.
2014-03-17 03:03:53 +01:00
2014-07-13 09:54:14 +02:00
### Via data attributes
2014-03-17 03:03:53 +01:00
2014-07-13 09:54:14 +02:00
Use data attributes to easily control the position of the carousel. `data-slide` accepts the keywords `prev` or `next` , which alters the slide position relative to its current position. Alternatively, use `data-slide-to` to pass a raw slide index to the carousel `data-slide-to="2"` , which shifts the slide position to a particular index beginning with `0` .
The `data-ride="carousel"` attribute is used to mark a carousel as animating starting at page load. **It cannot be used in combination with (redundant and unnecessary) explicit JavaScript initialization of the same carousel.**
### Via JavaScript
Call carousel manually with:
2014-03-17 03:03:53 +01:00
{% highlight js %}
$('.carousel').carousel()
{% endhighlight %}
2014-07-13 09:54:14 +02:00
### Options
Options can be passed via data attributes or JavaScript. For data attributes, append the option name to `data-` , as in `data-interval=""` .
< div class = "table-responsive" >
< table class = "table table-bordered table-striped" >
< thead >
< tr >
< th style = "width: 100px;" > Name< / th >
2015-10-27 19:42:36 +01:00
< th style = "width: 50px;" > Type< / th >
< th style = "width: 50px;" > Default< / th >
< th > Description< / th >
2014-07-13 09:54:14 +02:00
< / tr >
< / thead >
< tbody >
< tr >
< td > interval< / td >
< td > number< / td >
< td > 5000< / td >
< td > The amount of time to delay between automatically cycling an item. If false, carousel will not automatically cycle.< / td >
< / tr >
< tr >
< td > pause< / td >
2016-07-17 09:17:18 +02:00
< td > string | null< / td >
2014-07-13 09:54:14 +02:00
< td > "hover"< / td >
2016-07-17 09:17:18 +02:00
< td > If set to < code > "hover"< / code > , pauses the cycling of the carousel on < code > mouseenter< / code > and resumes the cycling of the carousel on < code > mouseleave< / code > . If set to < code > null< / code > , hovering over the carousel won't pause it.< / td >
2014-07-13 09:54:14 +02:00
< / tr >
< tr >
< td > wrap< / td >
< td > boolean< / td >
< td > true< / td >
< td > Whether the carousel should cycle continuously or have hard stops.< / td >
< / tr >
2014-10-27 06:31:59 +01:00
< tr >
< td > keyboard< / td >
< td > boolean< / td >
< td > true< / td >
< td > Whether the carousel should react to keyboard events.< / td >
< / tr >
2014-07-13 09:54:14 +02:00
< / tbody >
< / table >
< / div >
### Methods
2015-09-28 21:24:37 +02:00
#### `.carousel(options)`
2014-07-13 09:54:14 +02:00
Initializes the carousel with an optional options `object` and starts cycling through items.
2014-03-17 03:03:53 +01:00
{% highlight js %}
$('.carousel').carousel({
interval: 2000
})
{% endhighlight %}
2015-09-28 21:24:37 +02:00
#### `.carousel('cycle')`
2014-07-13 09:54:14 +02:00
Cycles through the carousel items from left to right.
2015-09-28 21:24:37 +02:00
#### `.carousel('pause')`
2014-07-13 09:54:14 +02:00
Stops the carousel from cycling through items.
2015-09-28 21:24:37 +02:00
#### `.carousel(number)`
2014-07-13 09:54:14 +02:00
Cycles the carousel to a particular frame (0 based, similar to an array).
2015-09-28 21:24:37 +02:00
#### `.carousel('prev')`
2014-07-13 09:54:14 +02:00
Cycles to the previous item.
2015-09-28 21:24:37 +02:00
#### `.carousel('next')`
2014-07-13 09:54:14 +02:00
Cycles to the next item.
### Events
Bootstrap's carousel class exposes two events for hooking into carousel functionality. Both events have the following additional properties:
- `direction` : The direction in which the carousel is sliding (either `"left"` or `"right"` ).
- `relatedTarget` : The DOM element that is being slid into place as the active item.
2015-03-01 22:44:10 +01:00
All carousel events are fired at the carousel itself (i.e. at the `<div class="carousel">` ).
2014-07-13 09:54:14 +02:00
< div class = "table-responsive" >
< table class = "table table-bordered table-striped" >
< thead >
< tr >
< th style = "width: 150px;" > Event Type< / th >
< th > Description< / th >
< / tr >
< / thead >
< tbody >
< tr >
< td > slide.bs.carousel< / td >
< td > This event fires immediately when the < code > slide< / code > instance method is invoked.< / td >
< / tr >
< tr >
< td > slid.bs.carousel< / td >
< td > This event is fired when the carousel has completed its slide transition.< / td >
< / tr >
< / tbody >
< / table >
< / div >
2014-03-17 03:03:53 +01:00
{% highlight js %}
$('#myCarousel').on('slide.bs.carousel', function () {
// do something…
})
{% endhighlight %}