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
2017-05-28 08:01:14 +02:00
toc: true
2014-07-12 11:20:15 +02:00
---
2017-05-28 08:01:14 +02:00
## How it works
2016-12-05 05:06:45 +01:00
The carousel is a slideshow for cycling through a series of content, built with CSS 3D transforms and a bit of JavaScript. It works with a series of images, text, or custom markup. It also includes support for previous/next controls and indicators.
In browsers where the [Page Visibility API ](https://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.).
2018-11-03 19:23:26 +01:00
{% include callout-info-prefersreducedmotion.md %}
2016-12-05 05:37:21 +01:00
Please be aware that nested carousels are not supported, and carousels are generally not compliant with accessibility standards.
2014-07-13 09:54:14 +02:00
2017-10-20 09:44:03 +02:00
Lastly, if you're building our JavaScript from source, it [requires `util.js` ]({{ site.baseurl }}/docs/{{ site.docs_version }}/getting-started/javascript/#util ).
2017-08-11 07:38:45 +02:00
2014-09-18 00:21:31 +02:00
## Example
2014-07-13 09:54:14 +02:00
2016-12-05 05:37:21 +01:00
Carousels don't automatically normalize slide dimensions. As such, you may need to use additional utilities or custom styles to appropriately size content. While carousels support previous/next controls and indicators, they're not explicitly required. Add and customize as you see fit.
2016-12-05 05:07:01 +01:00
2018-03-13 08:31:37 +01:00
**The `.active` class needs to be added to one of the slides** otherwise the carousel will not be visible. Also be sure to set a unique id on the `.carousel` for optional controls, especially if you're using multiple carousels on a single page. Control and indicator elements must have a `data-target` attribute (or `href` for links) that matches the id of the `.carousel` element.
2016-12-05 05:07:01 +01:00
### Slides only
2018-02-18 19:22:41 +01:00
Here's a carousel with slides only. Note the presence of the `.d-block` and `.w-100` on carousel images to prevent browser default image alignment.
2016-12-05 05:07:01 +01:00
2018-03-14 16:44:38 +01:00
{% capture example %}
2016-12-05 05:07:01 +01:00
< div id = "carouselExampleSlidesOnly" class = "carousel slide" data-ride = "carousel" >
2017-04-11 12:12:30 +02:00
< div class = "carousel-inner" >
2016-12-05 05:07:01 +01:00
< div class = "carousel-item active" >
2018-12-13 14:09:47 +01:00
{% include icons/placeholder.svg width="800" height="400" class="bd-placeholder-img-lg d-block w-100" color="#555" background="#777" text="First slide" %}
2016-12-05 05:07:01 +01:00
< / div >
< div class = "carousel-item" >
2018-12-13 14:09:47 +01:00
{% include icons/placeholder.svg width="800" height="400" class="bd-placeholder-img-lg d-block w-100" color="#444" background="#666" text="Second slide" %}
2016-12-05 05:07:01 +01:00
< / div >
< div class = "carousel-item" >
2018-12-13 14:09:47 +01:00
{% include icons/placeholder.svg width="800" height="400" class="bd-placeholder-img-lg d-block w-100" color="#333" background="#555" text="Third slide" %}
2016-12-05 05:07:01 +01:00
< / div >
< / div >
< / div >
2018-03-14 16:44:38 +01:00
{% endcapture %}
{% include example.html content=example %}
2016-12-05 05:07:01 +01:00
### With controls
Adding in the previous and next controls:
2018-03-14 16:44:38 +01:00
{% capture example %}
2016-12-05 05:07:01 +01:00
< div id = "carouselExampleControls" class = "carousel slide" data-ride = "carousel" >
2017-04-11 12:12:30 +02:00
< div class = "carousel-inner" >
2016-12-05 05:07:01 +01:00
< div class = "carousel-item active" >
2018-12-13 14:09:47 +01:00
{% include icons/placeholder.svg width="800" height="400" class="bd-placeholder-img-lg d-block w-100" color="#555" background="#777" text="First slide" %}
2016-12-05 05:07:01 +01:00
< / div >
< div class = "carousel-item" >
2018-12-13 14:09:47 +01:00
{% include icons/placeholder.svg width="800" height="400" class="bd-placeholder-img-lg d-block w-100" color="#444" background="#666" text="Second slide" %}
2016-12-05 05:07:01 +01:00
< / div >
< div class = "carousel-item" >
2018-12-13 14:09:47 +01:00
{% include icons/placeholder.svg width="800" height="400" class="bd-placeholder-img-lg d-block w-100" color="#333" background="#555" text="Third slide" %}
2016-12-05 05:07:01 +01:00
< / div >
< / div >
2016-12-05 08:19:54 +01:00
< a class = "carousel-control-prev" href = "#carouselExampleControls" role = "button" data-slide = "prev" >
2016-12-05 07:05:16 +01:00
< span class = "carousel-control-prev-icon" aria-hidden = "true" > < / span >
2016-12-05 05:07:01 +01:00
< span class = "sr-only" > Previous< / span >
< / a >
2016-12-05 08:19:54 +01:00
< a class = "carousel-control-next" href = "#carouselExampleControls" role = "button" data-slide = "next" >
2016-12-05 07:05:16 +01:00
< span class = "carousel-control-next-icon" aria-hidden = "true" > < / span >
2016-12-05 05:07:01 +01:00
< span class = "sr-only" > Next< / span >
< / a >
< / div >
2018-03-14 16:44:38 +01:00
{% endcapture %}
{% include example.html content=example %}
2016-12-05 05:07:01 +01:00
### With indicators
You can also add the indicators to the carousel, alongside the controls, too.
2016-10-27 18:19:07 +02:00
2018-03-14 16:44:38 +01:00
{% capture example %}
2016-12-05 05:07:01 +01:00
< div id = "carouselExampleIndicators" class = "carousel slide" data-ride = "carousel" >
2014-03-17 03:03:53 +01:00
< ol class = "carousel-indicators" >
2016-12-05 05:07:01 +01:00
< li data-target = "#carouselExampleIndicators" data-slide-to = "0" class = "active" > < / li >
< li data-target = "#carouselExampleIndicators" data-slide-to = "1" > < / li >
< li data-target = "#carouselExampleIndicators" data-slide-to = "2" > < / li >
2014-03-17 03:03:53 +01:00
< / ol >
2017-04-11 12:12:30 +02:00
< div class = "carousel-inner" >
2014-12-18 03:30:16 +01:00
< div class = "carousel-item active" >
2018-12-13 14:09:47 +01:00
{% include icons/placeholder.svg width="800" height="400" class="bd-placeholder-img-lg d-block w-100" color="#555" background="#777" text="First slide" %}
2014-03-17 03:03:53 +01:00
< / div >
2014-12-18 03:30:16 +01:00
< div class = "carousel-item" >
2018-12-13 14:09:47 +01:00
{% include icons/placeholder.svg width="800" height="400" class="bd-placeholder-img-lg d-block w-100" color="#444" background="#666" text="Second slide" %}
2014-07-13 09:54:14 +02:00
< / div >
2014-12-18 03:30:16 +01:00
< div class = "carousel-item" >
2018-12-13 14:09:47 +01:00
{% include icons/placeholder.svg width="800" height="400" class="bd-placeholder-img-lg d-block w-100" color="#333" background="#555" text="Third slide" %}
2014-04-01 22:03:14 +02:00
< / div >
2014-03-17 03:03:53 +01:00
< / div >
2016-12-05 08:19:54 +01:00
< a class = "carousel-control-prev" href = "#carouselExampleIndicators" role = "button" data-slide = "prev" >
2016-12-05 07:05:16 +01:00
< span class = "carousel-control-prev-icon" 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 >
2016-12-05 08:19:54 +01:00
< a class = "carousel-control-next" href = "#carouselExampleIndicators" role = "button" data-slide = "next" >
2016-12-05 07:05:16 +01:00
< span class = "carousel-control-next-icon" 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 >
2018-03-14 16:44:38 +01:00
{% endcapture %}
{% include example.html content=example %}
2014-03-17 03:03:53 +01:00
2016-12-05 05:37:21 +01:00
### With captions
2014-07-13 09:54:14 +02:00
2017-07-02 21:00:24 +02:00
Add captions to your slides easily with the `.carousel-caption` element within any `.carousel-item` . They can be easily hidden on smaller viewports, as shown below, with optional [display utilities ]({{ site.baseurl }}/docs/{{ site.docs_version }}/utilities/display/ ). We hide them initially with `.d-none` and bring them back on medium-sized devices with `.d-md-block` .
2014-07-13 09:54:14 +02:00
2019-02-06 10:13:55 +01:00
{% capture example %}
2015-04-16 23:07:20 +02:00
< div class = "bd-example" >
2016-12-05 05:37:21 +01:00
< div id = "carouselExampleCaptions" class = "carousel slide" data-ride = "carousel" >
2014-07-13 09:54:14 +02:00
< ol class = "carousel-indicators" >
2016-12-05 05:37:21 +01:00
< li data-target = "#carouselExampleCaptions" data-slide-to = "0" class = "active" > < / li >
< li data-target = "#carouselExampleCaptions" data-slide-to = "1" > < / li >
< li data-target = "#carouselExampleCaptions" data-slide-to = "2" > < / li >
2014-07-13 09:54:14 +02:00
< / ol >
2017-04-11 12:12:30 +02:00
< div class = "carousel-inner" >
2014-12-18 03:30:16 +01:00
< div class = "carousel-item active" >
2018-12-13 14:09:47 +01:00
{% include icons/placeholder.svg width="800" height="400" class="bd-placeholder-img-lg d-block w-100" color="#555" background="#777" text="First slide" %}
2016-12-05 05:37:21 +01:00
< div class = "carousel-caption d-none d-md-block" >
2017-12-25 05:06:33 +01:00
< h5 > First slide label< / h5 >
2014-07-13 09:54:14 +02:00
< 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" >
2018-12-13 14:09:47 +01:00
{% include icons/placeholder.svg width="800" height="400" class="bd-placeholder-img-lg d-block w-100" color="#444" background="#666" text="Second slide" %}
2016-12-05 05:37:21 +01:00
< div class = "carousel-caption d-none d-md-block" >
2017-12-25 05:06:33 +01:00
< h5 > Second slide label< / h5 >
2014-07-13 09:54:14 +02:00
< 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" >
2018-12-13 14:09:47 +01:00
{% include icons/placeholder.svg width="800" height="400" class="bd-placeholder-img-lg d-block w-100" color="#333" background="#555" text="Third slide" %}
2016-12-05 05:37:21 +01:00
< div class = "carousel-caption d-none d-md-block" >
2017-12-25 05:06:33 +01:00
< h5 > Third slide label< / h5 >
2014-07-13 09:54:14 +02:00
< p > Praesent commodo cursus magna, vel scelerisque nisl consectetur.< / p >
2014-03-17 03:03:53 +01:00
< / div >
< / div >
< / div >
2017-01-01 08:09:45 +01:00
< a class = "carousel-control-prev" href = "#carouselExampleCaptions" role = "button" data-slide = "prev" >
< span class = "carousel-control-prev-icon" aria-hidden = "true" > < / span >
2014-07-13 09:54:14 +02:00
< span class = "sr-only" > Previous< / span >
< / a >
2017-01-01 08:09:45 +01:00
< a class = "carousel-control-next" href = "#carouselExampleCaptions" role = "button" data-slide = "next" >
< span class = "carousel-control-next-icon" aria-hidden = "true" > < / span >
2014-07-13 09:54:14 +02:00
< span class = "sr-only" > Next< / span >
< / a >
< / div >
< / div >
2019-02-06 10:13:55 +01:00
{% endcapture %}
{% include example.html content=example %}
2014-03-17 03:03:53 +01:00
2018-01-22 07:51:08 +01:00
### Crossfade
Add `.carousel-fade` to your carousel to animate slides with a fade transition instead of a slide.
2018-03-14 16:44:38 +01:00
{% capture example %}
2018-01-22 07:51:08 +01:00
< div id = "carouselExampleFade" class = "carousel slide carousel-fade" data-ride = "carousel" >
< div class = "carousel-inner" >
< div class = "carousel-item active" >
2018-12-13 14:09:47 +01:00
{% include icons/placeholder.svg width="800" height="400" class="bd-placeholder-img-lg d-block w-100" color="#555" background="#777" text="First slide" %}
2018-01-22 07:51:08 +01:00
< / div >
< div class = "carousel-item" >
2018-12-13 14:09:47 +01:00
{% include icons/placeholder.svg width="800" height="400" class="bd-placeholder-img-lg d-block w-100" color="#444" background="#666" text="Second slide" %}
2018-01-22 07:51:08 +01:00
< / div >
< div class = "carousel-item" >
2018-12-13 14:09:47 +01:00
{% include icons/placeholder.svg width="800" height="400" class="bd-placeholder-img-lg d-block w-100" color="#333" background="#555" text="Third slide" %}
2018-01-22 07:51:08 +01:00
< / div >
< / div >
< a class = "carousel-control-prev" href = "#carouselExampleFade" role = "button" data-slide = "prev" >
< span class = "carousel-control-prev-icon" aria-hidden = "true" > < / span >
< span class = "sr-only" > Previous< / span >
< / a >
< a class = "carousel-control-next" href = "#carouselExampleFade" role = "button" data-slide = "next" >
< span class = "carousel-control-next-icon" aria-hidden = "true" > < / span >
< span class = "sr-only" > Next< / span >
< / a >
< / div >
2018-09-18 14:55:48 +02:00
{% endcapture %}
{% include example.html content=example %}
### Individual `.carousel-item` interval
Add `data-interval=""` to a `.carousel-item` to change the amount of time to delay between automatically cycling to the next item.
{% capture example %}
< div id = "carouselExampleInterval" class = "carousel slide" data-ride = "carousel" >
< div class = "carousel-inner" >
< div class = "carousel-item active" data-interval = "10000" >
2018-12-13 14:09:47 +01:00
{% include icons/placeholder.svg width="800" height="400" class="bd-placeholder-img-lg d-block w-100" color="#555" background="#777" text="First slide" %}
2018-09-18 14:55:48 +02:00
< / div >
2018-11-08 18:33:02 +01:00
< div class = "carousel-item" data-interval = "2000" >
2018-12-13 14:09:47 +01:00
{% include icons/placeholder.svg width="800" height="400" class="bd-placeholder-img-lg d-block w-100" color="#444" background="#666" text="Second slide" %}
2018-09-18 14:55:48 +02:00
< / div >
< div class = "carousel-item" >
2018-12-13 14:09:47 +01:00
{% include icons/placeholder.svg width="800" height="400" class="bd-placeholder-img-lg d-block w-100" color="#333" background="#555" text="Third slide" %}
2018-09-18 14:55:48 +02:00
< / div >
< / div >
< a class = "carousel-control-prev" href = "#carouselExampleInterval" role = "button" data-slide = "prev" >
< span class = "carousel-control-prev-icon" aria-hidden = "true" > < / span >
< span class = "sr-only" > Previous< / span >
< / a >
< a class = "carousel-control-next" href = "#carouselExampleInterval" role = "button" data-slide = "next" >
< span class = "carousel-control-next-icon" aria-hidden = "true" > < / span >
< span class = "sr-only" > Next< / span >
< / a >
< / div >
2018-03-14 16:44:38 +01:00
{% endcapture %}
{% include example.html content=example %}
2018-01-22 07:51:08 +01:00
2014-07-13 09:54:14 +02:00
## Usage
### 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` .
2019-01-04 17:15:01 +01:00
The `data-ride="carousel"` attribute is used to mark a carousel as animating starting at page load. If you don't use `data-ride="carousel"` to initialize your carousel, you have to initialize it yourself. **It cannot be used in combination with (redundant and unnecessary) explicit JavaScript initialization of the same carousel.**
2014-07-13 09:54:14 +02:00
### 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=""` .
2017-12-27 22:40:51 +01:00
< table class = "table table-bordered table-striped" >
2017-01-01 01:12:28 +01:00
< thead >
2017-04-28 00:57:10 +02:00
< tr >
< th style = "width: 100px;" > Name< / th >
< th style = "width: 50px;" > Type< / th >
< th style = "width: 50px;" > Default< / th >
< th > Description< / th >
< / tr >
2017-01-01 01:12:28 +01:00
< / thead >
< tbody >
2017-04-28 00:57:10 +02:00
< 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 > keyboard< / td >
< td > boolean< / td >
< td > true< / td >
< td > Whether the carousel should react to keyboard events.< / td >
< / tr >
< tr >
< td > pause< / td >
< td > string | boolean< / td >
< td > "hover"< / td >
< td > < p > 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 > false< / code > , hovering over the carousel won't pause it.< / p >
< p > On touch-enabled devices, when set to < code > "hover"< / code > , cycling will pause on < code > touchend< / code > (once the user finished interacting with the carousel) for two intervals, before automatically resuming. Note that this is in addition to the above mouse behavior.< / p > < / td >
< / tr >
< tr >
< td > ride< / td >
< td > string< / td >
< td > false< / td >
< td > Autoplays the carousel after the user manually cycles the first item. If "carousel", autoplays the carousel on load.< / td >
< / tr >
< tr >
< td > wrap< / td >
< td > boolean< / td >
< td > true< / td >
< td > Whether the carousel should cycle continuously or have hard stops.< / td >
< / tr >
2018-03-03 22:04:11 +01:00
< tr >
< td > touch< / td >
< td > boolean< / td >
< td > true< / td >
2018-10-14 13:59:51 +02:00
< td > Whether the carousel should support left/right swipe interactions on touchscreen devices.< / td >
2018-03-03 22:04:11 +01:00
< / tr >
2017-01-01 01:12:28 +01:00
< / tbody >
< / table >
2014-07-13 09:54:14 +02:00
### Methods
2018-01-15 23:49:36 +01:00
{% include callout-danger-async-methods.md %}
2017-03-28 23:43:16 +02:00
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
2017-03-28 23:43:16 +02:00
Cycles the carousel to a particular frame (0 based, similar to an array). **Returns to the caller before the target item has been shown** (i.e. before the `slid.bs.carousel` event occurs).
2014-07-13 09:54:14 +02:00
2015-09-28 21:24:37 +02:00
#### `.carousel('prev')`
2014-07-13 09:54:14 +02:00
2017-03-28 23:43:16 +02:00
Cycles to the previous item. **Returns to the caller before the previous item has been shown** (i.e. before the `slid.bs.carousel` event occurs).
2014-07-13 09:54:14 +02:00
2015-09-28 21:24:37 +02:00
#### `.carousel('next')`
2014-07-13 09:54:14 +02:00
2017-03-28 23:43:16 +02:00
Cycles to the next item. **Returns to the caller before the next item has been shown** (i.e. before the `slid.bs.carousel` event occurs).
2014-07-13 09:54:14 +02:00
2017-10-30 14:51:46 +01:00
#### `.carousel('dispose')`
2017-10-16 16:51:42 +02:00
Destroys an element's carousel.
2014-07-13 09:54:14 +02:00
### 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.
2017-03-22 22:42:13 +01:00
- `from` : The index of the current item
- `to` : The index of the next item
2014-07-13 09:54:14 +02:00
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
2017-12-27 22:40:51 +01:00
< table class = "table table-bordered table-striped" >
2017-01-01 01:12:28 +01:00
< thead >
2017-04-28 00:57:10 +02:00
< tr >
< th style = "width: 150px;" > Event Type< / th >
< th > Description< / th >
< / tr >
2017-01-01 01:12:28 +01:00
< / thead >
< tbody >
2017-04-28 00:57:10 +02:00
< 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 >
2017-01-01 01:12:28 +01:00
< / tbody >
< / table >
2014-07-13 09:54:14 +02:00
2014-03-17 03:03:53 +01:00
{% highlight js %}
$('#myCarousel').on('slide.bs.carousel', function () {
// do something…
})
{% endhighlight %}
2018-02-19 10:10:25 +01:00
### Change transition duration
2018-03-13 09:59:20 +01:00
The transition duration of `.carousel-item` can be changed with the `$carousel-transition` Sass variable before compiling or custom styles if you're using the compiled CSS. If multiple transitions are applied, make sure the transform transition is defined first (eg. `transition: transform 2s ease, opacity .5s ease-out` ).