An extensible low level carousel for the web, written in TypeScript.
Embla's purpose is to provide a low level carousel and allow developers to extend it by using its available methods. Extend it with some very basic JavaScript and build awesome physics-based carousels. It's dependency free and 100% open source.
See the demo page or try Embla Carousel on CodeSandbox.
If you are using a module bundler...
yarn add embla-carousel
import EmblaCarousel from 'embla-carousel'
const embla = EmblaCarousel(document.getElementById('embla'))
...or manually inject this script into your website.
<script src="embla.min.js"></script>
<script>
const embla = EmblaCarousel(document.getElementById('embla'))
</script>
Setup your HTML markup...
<div class="embla" id="embla">
<div class="embla__container">
<div class="embla__slide">
...
</div>
<div class="embla__slide">
...
</div>
<div class="embla__slide">
...
</div>
</div>
</div>
...add some CSS...
.embla {
overflow: hidden;
}
.embla__container {
display: flex;
will-change: transform;
}
.embla__slide {
position: relative;
flex: 0 0 auto;
width: 100%;
}
...initialize the script and pass the element node...
import EmblaCarousel from 'embla-carousel'
const embla = EmblaCarousel(document.getElementById('embla'))
...and you're good to go!
Embla comes with a few optional settings that you can change by passing an object as the second argument. Default values are:
const node = document.getElementById('embla')
const embla = EmblaCarousel(node, {
align: 'center',
containerSelector: '*',
groupSlides: 1,
draggable: true,
dragFree: false,
loop: false,
speed: 10,
startIndex: 0,
selectedClass: 'is-selected',
draggableClass: 'is-draggable',
draggingClass: 'is-dragging',
})
align
(string: start | center | end)
Align the slides relative to the carousel viewport.
containerSelector
(string: querySelectorString)
The selector to use for the container that holds the slides. Embla will use all immediate children of this node as slides.
groupSlides
(number)
Groups slides together into groups of given size and makes each group act as a single slide.
draggable
(boolean)
Allow mouse and touch interactions to move the carousel.
dragFree
(boolean)
Determines if the carousel should snap to a slide position after mouse and touch interactions.
loop
(boolean)
Determines if the carousel should loop when start or end is reached.
speed
(number: 5 - 20)
Carousel speed when using buttons to navigate. A higher number will make transitions faster. Pointer events are not affected by this.
startIndex
(number)
Zero based index of the starting slide when carousel mounts.
selectedClass
(string)
Classname that will be applied to the selected slide.
draggableClass
(string)
Classname that will be applied to the wrapper when the carousel mounts if draggable is set to true.
draggingClass
(string)
Classname that will be applied to the wrapper when a pointer is dragging the carousel.
Embla exposes a set of methods upon setup that can be used to control the carousel externally. Example usage looks like this...
import EmblaCarousel from 'embla-carousel'
const embla = EmblaCarousel(document.getElementById('embla'))
embla.next()
...and the methods are:
containerNode()
Returns the current container element node.
slideNodes()
Returns the slides as an array of element nodes.
selectedIndex()
Returns the current selected index. Each index contains multiple slides if groupSlides
options is set to more than 1
. If groupCells
is set to 1
each slide has its own index. Zero-based.
previousIndex()
Returns the previous selected index. Each index contains multiple slides if groupSlides
options is set to more than 1
. If groupCells
is set to 1
each slide has its own index. Zero-based.
groupedIndexes()
Returns an array of all slide indexes grouped into arrays according to the groupSlides
option, i.e. if the total number of slides is 4
and groupSlides
is set to 2
, it will return [[0, 1], [2, 3]]
.
next()
Moves to next item. If loop
option is set to false
and the carousel is on the last slide this method will do nothing.
previous()
Moves to previous item. If loop
option is set to false
and the carousel is on the first slide this method will do nothing.
goTo(index: number)
Moves to item that matches passed index. If loop
option is set to true
the carousel will seek the closest way to the passed index.
changeOptions(options: options)
Applies passed options by doing all the necessary calculations and reinitialising the carousel from scratch.
on(event: string, callback: function)
Subscribes to a custom Embla event by firing the passed callback. Below is a list of events you can subscribe to:
init
- Triggers after the carousel has been initialised for the first time.destroy
- Triggers after the carousel has been destroyed.select
- Triggers when a new target slide has been selected.dragStart
- Triggers when carousel dragging begins.dragEnd
- Triggers when carousel dragging ends.
off(event: string, callback: function)
Ends subscription to a custom Embla event by removing the passed callback. This works for all events listed on the on method.
destroy()
Removes all styles applied to DOM nodes and kills all event listeners for this Embla instance.
Embla is MIT licensed.