Skip to content
My content My content My content My content My content My content My content My content
Carousel ⚠️ Experimental
The Carousel component can be used imported from:
Playground
Parameters
Events
This component has events. Check the documentation about how to use the events.
Name | Payload | Description |
---|---|---|
change | number | Fires when the slide changes |
Slots
This component has slots. Check the documentation about how to use the slots.
Name | Tags | Description |
---|---|---|
slide-<number> | span | Slot for the slide content. The number is the index of the slide. |
Parameters use
Check the documentation about how to use the parameters.
config
The config
attribute is used to customize the interaction components of the carousel. The interaction components are the dots and the navigation arrows.
The first modifier is the arrows
styling. The possible values are: circle
, chevron
or semi
.
The second modifier is the dots
position. Possible values are: center
, left
, right
.
The third modifier adds navigation to the dots using nav
. Requires some dots
config.
You can combine the two modifiers separating them with a (:
). The patter would be <?arrows>:<?dots>:<?nav>
.
delay
The delay
attribute is used to define the time in milliseconds between each slide.
Slides
Make sure for each slide to use the slot
attribute with the value slide-<number>
. The number should be incremental.
Special uses
Card gallery
We can create nice galleries using the overflow version of Carousel
. We recommend to set the no-loop
flag and play with the --z-carousel--squint
value. The gallery navigation can be done in chunks, where those have the same gap as the carousel slides to make a continuos effect.
So adding some style:
scss
---
title: Carousel
titleTemplate: Guidelines
description: ZDS components
---
<!-- markdownlint-disable MD025 -->
# Carousel
<script setup>
import { useGuidelinesImports } from '../_fragments/guidelines_imports';
import { meta } from './carousel.meta';
import '~web/layouts/z-carousel';
const {
DocsParams,
DocsCardsCarousel,
DocsCodeAndRender,
DocsImplementationSelector,
DocsImplementationTable,
DocsCustomTokens,
} = useGuidelinesImports();
</script>
<style lang="scss" scoped>
#header-sample {
background-color: #fafafa;
padding: var(--zs-300);
*[slot^="slide-"] {
display: grid;
place-items: center;
height: 100%;
font: var(--zf-body-20--600);
}
}
</style>
<docs-implementation-selector :meta/>
<section id="header-sample">
<z-carousel config="semi:center:nav">
<div slot="slide-1">Slide 1</div>
<div slot="slide-2">Slide 2</div>
<div slot="slide-3">Slide 3</div>
</z-carousel>
</section>
Carousels allow displaying a related set of content items in a limited space, by splitting the content
into different frames. Users can navigate a carousel by interacting with the carousel arrows or dots
pagination in larger viewports, or by a swipe gesture on tablet and mobile apps.
Stages, modals, articles collections and image galleries are all elements that can be displayed as carousels.
::: info UX/UI Guidelines
Check the design documentation of the component in [ZeroHeight](https://design.zurich.com/50ae7978d/p/648801-carousel).
:::
## Implementations
<docs-implementation-table :meta/>
## Parameters
<!--@include: ../_fragments/params_info.md-->
<docs-params :meta>
<!--@include: ../_fragments/base_params.md-->
</docs-params>
## From Figma to code
...
<!-- ![alt text](./assets/Button/FigmaProps.png)
- `z-theme`: Default (`light`) or Alternate (`dark`) -->
## Customization
<!--@include: ../_fragments/customization.md-->
<!-- <docs-code-and-render sameCode :lang z-flex="col:100">
</docs-code-and-render> -->
## Accessibility
...
<!--@include: ../_fragments/related_components.md-->
We can the write the component:
Browser support
Detected engine:
Chromium
Webkit
Gecko