A configurable rotating content carousel for displaying images or arbitrary content.


<!-- include carousel.css -->
<link rel="stylesheet" href="carousel.css">
<link rel="stylesheet" href="carousel-style.css">

<!-- the viewport -->
<div class="m-carousel m-fluid m-carousel-photos">
  <!-- the slider -->
  <div class="m-carousel-inner">
    <!-- the items -->
    <div class="m-item m-active">
      <img src="image1.jpg">
    <div class="m-item">
      <img src="image2.jpg">
    <div class="m-item">
      <img src="image3.jpg">
  <!-- the controls -->
  <div class="m-carousel-controls m-carousel-bulleted">
    <a href="#" data-slide="prev">Previous</a>
    <a href="#" data-slide="1" class="m-active">1</a>
    <a href="#" data-slide="2">2</a>
    <a href="#" data-slide="3">3</a>
    <a href="#" data-slide="next">Next</a>

<!-- include zepto.js or jquery.js -->
<script src="zepto.js"></script>
<!-- include carousel.js -->
<script src="carousel.js"></script>
<!-- construct the carousel -->


By default, items are center aligned and their width is determined by their content width and/or any styling that restricts their width.

To change the styling of the items, add the following classes to the viewport:

Class Description
.m-fluid Causes the width of items to resize to match the viewport width.
.m-center Causes the items to be center aligned, not left aligned (the default).



Constructs the carousel with options.

      dragRadius: 10
    , moveRadius: 20
    , classPrefix: undefined
    , classNames: {
        outer: "carousel"
      , inner: "carousel-inner"
      , item: "item"
      , center: "center"
      , touch: "has-touch"
      , dragging: "dragging"
      , active: "active"


Moves the carousel one item to the right.



Moves the carousel one item to the left.


.carousel(‘move’, x)

Moves the carousel to a index x (1-based).

$('.m-carousel').carousel('move', 1);


Removes event handlers bound on the carousel.



Binds the event handlers on the carousel.



Removes the carousel and its event handlers from the DOM.



The viewport emits the following events:

Name Arguments Description
beforeSlide previousIndex, newIndex Fired before the carousel moves.
afterSlide previousIndex, newIndex Fired after the carousel begins moving.

Browser Compatibility

Mobile Browsers

The following mobile browsers are fully supported:

Browser Version
Mobile Safari 3.1.3+
Android Browser 2.1+
Android Chrome 1.0+
Android Firefox 1.0+

The following mobile browsers have degraded support:

Browser Version
Windows Phone 7.5

Desktop Browsers

The follow desktop browsers are fully supported:

Browser Version
Safari 4.0+
Firefox 4.0+
Chrome 12.0+
Opera 12.0+
Internet Explorer 10.0+

The following desktop browsers have degraded support:

Browser Version
Internet Explorer 8.0,9.0
Firefox 3.5,3.6