Components
- Accordion
- Alert
- Alert Dialog
- Aspect Ratio
- Avatar
- Badge
- Breadcrumb
- Button
- Button Group
- Calendar
- Card
- Carousel
- Chart
- Checkbox
- Collapsible
- Combobox
- Command
- Context Menu
- Data Table
- Date Picker
- Dialog
- Direction
- Drawer
- Dropdown Menu
- Empty
- Field
- Hover Card
- Input
- Input Group
- Input OTP
- Item
- Kbd
- Label
- Menubar
- Native Select
- Navigation Menu
- Pagination
- Popover
- Progress
- Radio Group
- Resizable
- Scroll Area
- Select
- Separator
- Sheet
- Sidebar
- Skeleton
- Slider
- Sonner
- Spinner
- Switch
- Table
- Tabs
- Textarea
- Toast
- Toggle
- Toggle Group
- Tooltip
- Typography
Get Started
Processing payment...
$100.00
import {
Item,
ItemContent,安装
pnpm dlx shadcn@latest add spinner
用法
import { Spinner } from "@/components/ui/spinner"<Spinner />自定义
你可以通过编辑 Spinner 组件,把默认 spinner 图标替换成任意其他图标。
import { LoaderIcon } from "lucide-react"
import { cn } from "@/lib/utils"import { LoaderIcon } from "lucide-react"
import { cn } from "@/lib/utils"
function Spinner({ className, ...props }: React.ComponentProps<"svg">) {
return (
<LoaderIcon
role="status"
aria-label="Loading"
className={cn("size-4 animate-spin", className)}
{...props}
/>
)
}
export { Spinner }示例
尺寸
使用 size-* 工具类改变 spinner 的大小。
import { Spinner } from "@/components/ui/spinner"
export function SpinnerSize() {按钮
在按钮中添加 spinner 可以表示加载状态。将 <Spinner /> 放在标签前面并使用 data-icon="inline-start" 表示起始位置,或者放在标签后面并使用 data-icon="inline-end" 表示结束位置。
import { Button } from "@/components/ui/button"
import { Spinner } from "@/components/ui/spinner"
徽标
在徽标中添加 spinner 可以表示加载状态。将 <Spinner /> 放在标签前面并使用 data-icon="inline-start" 表示起始位置,或者放在标签后面并使用 data-icon="inline-end" 表示结束位置。
SyncingUpdatingProcessing
import { Badge } from "@/components/ui/badge"
import { Spinner } from "@/components/ui/spinner"
Input Group
Validating...
import {
InputGroup,
InputGroupAddon,Empty
Processing your request
Please wait while we process your request. Do not refresh the page.
import { Button } from "@/components/ui/button"
import {
Empty,RTL
要在 shadcn/ui 中启用 RTL 支持,请参见 RTL 配置指南。
جاري معالجة الدفع...
١٠٠.٠٠ دولار
"use client"
import * as React from "react"