Carousel
Examples
data:image/s3,"s3://crabby-images/bc49c/bc49cc50030dc39b35f47b4fd68b7f41ae1dab19" alt="cosmic-timetraveler-pYyOZ8q7AII-unsplash.com Cosmic timetraveler"
Cosmic timetraveler
data:image/s3,"s3://crabby-images/bc49c/bc49cc50030dc39b35f47b4fd68b7f41ae1dab19" alt="Image from cosmic-timetraveler-pYyOZ8q7AII-unsplash.com Cosmic timetraveler"
data:image/s3,"s3://crabby-images/ee2a8/ee2a8ba4ec40371a929ccef4a2b6da8d50da50a4" alt="Image from cristina-gottardi-CSpjU6hYo_0-unsplash.com Cristina Gottardi"
data:image/s3,"s3://crabby-images/14d41/14d41b8c0fa59b8361a69d02fdb75db90513bb9d" alt="Image from johannes-plenio-RwHv7LgeC7s-unsplash.com Johannes Plenio"
data:image/s3,"s3://crabby-images/92b3e/92b3e50acd944698d10ff88b84e355b995a7f9b5" alt="Image from jonatan-pie-3l3RwQdHRHg-unsplash.com Jonatan Pie"
data:image/s3,"s3://crabby-images/489fd/489fd71813b83807a7a8fca444f3dc409f71e923" alt="Image from mark-harpur-K2s_YE031CA-unsplash Mark Harpur"
data:image/s3,"s3://crabby-images/73f19/73f193bb59e1217d0d44a10b7e39aa9974f0be2b" alt="Image from pietro-de-grandi-T7K4aEPoGGk-unsplash Pietro De Grandi"
data:image/s3,"s3://crabby-images/7857d/7857da649c9fbae2b4f11740576e01e4bf57606f" alt="Image from sergey-pesterev-tMvuB9se2uQ-unsplash Sergey Pesterev"
data:image/s3,"s3://crabby-images/76fb6/76fb68902e74b969bfc32fb740915d01a3386cca" alt="Image from solotravelgoals-7kLufxYoqWk-unsplash Solo travel goals"
<script>
import { Carousel } from '$lib/index';
const images = [
{
id: 0,
name: "Cosmic timetraveler",
imgurl: "/images/carousel/cosmic-timetraveler-pYyOZ8q7AII-unsplash.webp",
attribution: "cosmic-timetraveler-pYyOZ8q7AII-unsplash.com",
},
{
id: 1,
name: "Cristina Gottardi",
imgurl: "/images/carousel/cristina-gottardi-CSpjU6hYo_0-unsplash.webp",
attribution: "cristina-gottardi-CSpjU6hYo_0-unsplash.com",
},
{
id: 2,
name: "Johannes Plenio",
imgurl: "/images/carousel/johannes-plenio-RwHv7LgeC7s-unsplash.webp",
attribution: "johannes-plenio-RwHv7LgeC7s-unsplash.com",
},
{
id: 3,
name: "Jonatan Pie",
imgurl: "/images/carousel/jonatan-pie-3l3RwQdHRHg-unsplash.webp",
attribution: "jonatan-pie-3l3RwQdHRHg-unsplash.com",
},
{
id: 4,
name: "Mark Harpur",
imgurl: "/images/carousel/mark-harpur-K2s_YE031CA-unsplash.webp",
attribution: "mark-harpur-K2s_YE031CA-unsplash",
},
{
id: 5,
name: "Pietro De Grandi",
imgurl: "/images/carousel/pietro-de-grandi-T7K4aEPoGGk-unsplash.webp",
attribution: "pietro-de-grandi-T7K4aEPoGGk-unsplash",
},
{
id: 6,
name: "Sergey Pesterev",
imgurl: "/images/carousel/sergey-pesterev-tMvuB9se2uQ-unsplash.webp",
attribution: "sergey-pesterev-tMvuB9se2uQ-unsplash",
},
{
id: 7,
name: "Solo travel goals",
imgurl: "/images/carousel/solotravelgoals-7kLufxYoqWk-unsplash.webp",
attribution: "solotravelgoals-7kLufxYoqWk-unsplash",
},
];
</script>
<Carousel {images} />
Loop
Use `loop` prop to loop the carousel. Use `duration=number` to set the interval
data:image/s3,"s3://crabby-images/bc49c/bc49cc50030dc39b35f47b4fd68b7f41ae1dab19" alt="cosmic-timetraveler-pYyOZ8q7AII-unsplash.com Cosmic timetraveler"
<script>
let showThumbs=false
let showCaptions=false
</script>
<Carousel {images} loop {showCaptions} {showThumbs} duration="3000" />
Without thumbnails
The `showThumbs` is set to `true`. Set it to `false` to hide it.
data:image/s3,"s3://crabby-images/bc49c/bc49cc50030dc39b35f47b4fd68b7f41ae1dab19" alt="cosmic-timetraveler-pYyOZ8q7AII-unsplash.com Cosmic timetraveler"
Cosmic timetraveler
<script>
let showThumbs=false
</script>
<Carousel {images} {showThumbs}/>
Without caption
To hide the caption, set `showCaptions` to `false`.
data:image/s3,"s3://crabby-images/bc49c/bc49cc50030dc39b35f47b4fd68b7f41ae1dab19" alt="cosmic-timetraveler-pYyOZ8q7AII-unsplash.com Cosmic timetraveler"
<script>
let showThumbs=false
let showCaptions=false
</script>
<Carousel {images} {showThumbs} {showCaptions}/>
Without indicators
To hide the indicators, set `showIndicators` to `false`.
data:image/s3,"s3://crabby-images/bc49c/bc49cc50030dc39b35f47b4fd68b7f41ae1dab19" alt="cosmic-timetraveler-pYyOZ8q7AII-unsplash.com Cosmic timetraveler"
<script>
let showThumbs=false
let showCaptions=false
let showIndicators=false
</script>
<Carousel {images} {showThumbs} {showCaptions} {showIndicators}/>
Without slide controllers
To hide the slide controllers, set `slideControls` to `false`.
data:image/s3,"s3://crabby-images/bc49c/bc49cc50030dc39b35f47b4fd68b7f41ae1dab19" alt="cosmic-timetraveler-pYyOZ8q7AII-unsplash.com Cosmic timetraveler"
<script>
let showThumbs=false
let showCaptions=false
let slideControls=false
</script>
<Carousel {images} {showThumbs} {showCaptions} {slideControls}/>
Custom slide controllers
You can add custom slide controllers using Svelte-Heros icons. Change the size using the `iconSize` prop and style with the `iconClass` prop.
data:image/s3,"s3://crabby-images/bc49c/bc49cc50030dc39b35f47b4fd68b7f41ae1dab19" alt="cosmic-timetraveler-pYyOZ8q7AII-unsplash.com Cosmic timetraveler"
<script>
import {ChevronDoubleLeft, ChevronDoubleRight } from 'svelte-heros'
let icons={
next: ChevronDoubleRight,
prev: ChevronDoubleLeft,
}
let iconSize =20
let iconClass = 'text-white dark:text-red-500';
</script>
<div class="max-w-4xl">
<Carousel {images} {showThumbs} {showCaptions} {icons} {iconSize} {iconClass}/>
</div>
Props
The component has the following props, type, and default values. See types page for type information.
Name | Type | Default |
---|---|---|
showIndicators | boolean | true |
showCaptions | boolean | true |
showThumbs | boolean | true |
images | any[] | |
slideControls | boolean | true |
loop | boolean | false |
duration | number | 2000 |
icons | CarouselIconType | { next: ChevronRight, prev: ChevronLeft } |
iconSize | number | 24 |
iconClass | string | 'text-white sm:w-6 sm:h-6 dark:text-gray-300' |
divClass | string | 'overflow-hidden relative h-56 rounded-lg sm:h-64 xl:h-80 2xl:h-96' |
indicatorDivClass | string | 'flex absolute bottom-5 left-1/2 z-30 space-x-3 -translate-x-1/2' |
captionClass | string | 'h-10 bg-gray-300 dark:bg-gray-700 dark:text-white p-2 my-2 text-center' |
indicatorClass | string | 'w-3 h-3 rounded-full bg-gray-100 hover:bg-gray-300 opacity-60' |
slideClass | string | '' |