import * as React from "react"
import { Card, CardContent } from "@/components/ui/card"
import {关于
该轮播图组件是基于 Embla Carousel 库构建的。
安装
pnpm dlx shadcn@latest add carousel
用法
import {
Carousel,
CarouselContent,
CarouselItem,
CarouselNext,
CarouselPrevious,
} from "@/components/ui/carousel"<Carousel>
<CarouselContent>
<CarouselItem>...</CarouselItem>
<CarouselItem>...</CarouselItem>
<CarouselItem>...</CarouselItem>
</CarouselContent>
<CarouselPrevious />
<CarouselNext />
</Carousel>示例
大小
要设置项目的大小,可以在 <CarouselItem /> 上使用 basis 工具类。
import * as React from "react"
import { Card, CardContent } from "@/components/ui/card"// 占轮播图宽度的 33%。
<Carousel>
<CarouselContent>
<CarouselItem className="basis-1/3">...</CarouselItem>
<CarouselItem className="basis-1/3">...</CarouselItem>
<CarouselItem className="basis-1/3">...</CarouselItem>
</CarouselContent>
</Carousel>// 小屏幕占 50%,大屏幕占 33%。
<Carousel>
<CarouselContent>
<CarouselItem className="md:basis-1/2 lg:basis-1/3">...</CarouselItem>
<CarouselItem className="md:basis-1/2 lg:basis-1/3">...</CarouselItem>
<CarouselItem className="md:basis-1/2 lg:basis-1/3">...</CarouselItem>
</CarouselContent>
</Carousel>间距
要设置项目之间的间距,我们在 <CarouselItem /> 上使用 pl-[VALUE] 工具类,在 <CarouselContent /> 上使用负的 -ml-[VALUE]。
原因: 我尝试过在 <CarouselContent /> 上使用 gap 属性或 grid 布局,但需要大量计算和思考才能正确设置间距。我发现使用 pl-[VALUE] 和 -ml-[VALUE] 工具类更容易使用。
您也可以根据自己的项目需求调整该设置。
import * as React from "react"
import { Card, CardContent } from "@/components/ui/card"<Carousel>
<CarouselContent className="-ml-4">
<CarouselItem className="pl-4">...</CarouselItem>
<CarouselItem className="pl-4">...</CarouselItem>
<CarouselItem className="pl-4">...</CarouselItem>
</CarouselContent>
</Carousel><Carousel>
<CarouselContent className="-ml-2 md:-ml-4">
<CarouselItem className="pl-2 md:pl-4">...</CarouselItem>
<CarouselItem className="pl-2 md:pl-4">...</CarouselItem>
<CarouselItem className="pl-2 md:pl-4">...</CarouselItem>
</CarouselContent>
</Carousel>方向
使用 orientation 属性设置轮播图的方向。
import * as React from "react"
import { Card, CardContent } from "@/components/ui/card"
import {<Carousel orientation="vertical | horizontal">
<CarouselContent>
<CarouselItem>...</CarouselItem>
<CarouselItem>...</CarouselItem>
<CarouselItem>...</CarouselItem>
</CarouselContent>
</Carousel>选项
可以通过 opts 属性传递配置项给轮播图。更多信息请参见 Embla Carousel 文档。
<Carousel
opts={{
align: "start",
loop: true,
}}
>
<CarouselContent>
<CarouselItem>...</CarouselItem>
<CarouselItem>...</CarouselItem>
<CarouselItem>...</CarouselItem>
</CarouselContent>
</Carousel>API
使用状态和 setApi 属性获取轮播图 API 实例。
"use client"
import * as React from "react"import { type CarouselApi } from "@/components/ui/carousel"
export function Example() {
const [api, setApi] = React.useState<CarouselApi>()
const [current, setCurrent] = React.useState(0)
const [count, setCount] = React.useState(0)
React.useEffect(() => {
if (!api) {
return
}
setCount(api.scrollSnapList().length)
setCurrent(api.selectedScrollSnap() + 1)
api.on("select", () => {
setCurrent(api.selectedScrollSnap() + 1)
})
}, [api])
return (
<Carousel setApi={setApi}>
<CarouselContent>
<CarouselItem>...</CarouselItem>
<CarouselItem>...</CarouselItem>
<CarouselItem>...</CarouselItem>
</CarouselContent>
</Carousel>
)
}事件
您可以使用从 setApi 获得的 api 实例监听事件。
import { type CarouselApi } from "@/components/ui/carousel"
export function Example() {
const [api, setApi] = React.useState<CarouselApi>()
React.useEffect(() => {
if (!api) {
return
}
api.on("select", () => {
// 在选中时执行某些操作。
})
}, [api])
return (
<Carousel setApi={setApi}>
<CarouselContent>
<CarouselItem>...</CarouselItem>
<CarouselItem>...</CarouselItem>
<CarouselItem>...</CarouselItem>
</CarouselContent>
</Carousel>
)
}更多关于事件的使用信息,请参见 Embla Carousel 文档。
插件
您可以通过 plugins 属性给轮播图添加插件。
import Autoplay from "embla-carousel-autoplay"
export function Example() {
return (
<Carousel
plugins={[
Autoplay({
delay: 2000,
}),
]}
>
// ...
</Carousel>
)
}"use client"
import * as React from "react"更多关于插件的使用信息,请参见 Embla Carousel 文档。
RTL
要在 shadcn/ui 中启用 RTL(从右到左)支持,请参见 RTL 配置指南。
"use client"
import * as React from "react"在为 RTL 语言本地化轮播图时,您需要在 opts 属性中设置 direction 选项以匹配文本方向。这样可以确保轮播图按正确方向滚动。
<Carousel
dir={dir}
opts={{
direction: dir,
}}
>
<CarouselContent>
<CarouselItem>...</CarouselItem>
<CarouselItem>...</CarouselItem>
<CarouselItem>...</CarouselItem>
</CarouselContent>
<CarouselPrevious className="rtl:rotate-180" />
<CarouselNext className="rtl:rotate-180" />
</Carousel>direction 选项接受 "ltr" 或 "rtl",应与 dir 属性值匹配。您可能还需要使用 rtl:rotate-180 类旋转导航按钮,以确保它们指向正确方向。
API 参考
有关属性和插件的更多信息,请参见 Embla Carousel 文档。