Components
- 手风琴
- 提示
- 警告对话框
- 宽高比
- 头像
- 徽章
- 面包屑导航
- 按钮
- 按钮组
- 日历 Calendar
- 卡片
- Carousel
- 图表 Chart
- 复选框
- 折叠面板
- 组合框
- 命令
- 上下文菜单
- 数据表格 Data Table
- 日期选择器 Date Picker
- 对话框 Dialog
- 方向
- 抽屉
- 下拉菜单
- Empty
- 字段
- 悬停卡片
- 输入
- 输入组
- 输入 OTP
- 项目
- Kbd
- 标签
- 菜单栏
- 原生选择框
- 导航菜单 Navigation Menu
- 分页
- 弹出框
- 进度 Progress
- 单选框组
- 可调整大小
- 滚动区域 Scroll Area
- 选择框
- 分隔符 Separator
- 侧边栏 Sheet
- 侧边栏 Sidebar
- 骨架屏
- 滑块
- Sonner
- 加载指示器 Spinner
- 开关
- 表格
- 标签页 Tabs
- 文本域
- 吐司
- 切换按钮 Toggle
- 切换组
- 提示 Tooltip
- 排版
开始一个新项目? 使用 shadcn/create 来创建一个完全配置好的 Next.js 应用,包含自定义主题、Base UI 或 Radix 以及图标库。
创建项目
使用 --rtl 标志和 next 模板创建一个新的项目。
如果你已经使用 shadcn/create 创建过项目,可以跳过此步骤。
pnpm dlx shadcn@latest create --template next --rtl
这会创建一个带有 rtl: true 标志的 components.json 文件。
{
"$schema": "https://ui.shadcn.com/schema.json",
"style": "base-nova",
"rtl": true
}添加 DirectionProvider
使用带有 direction="rtl" 属性的 DirectionProvider 组件包裹你的应用。
然后在 html 标签上添加 dir="rtl" 和 lang="ar" 属性。将 lang="ar" 更新为你的目标语言。
import { DirectionProvider } from "@/components/ui/direction"
export default function RootLayout({
children,
}: {
children: React.ReactNode
}) {
return (
<html lang="ar" dir="rtl">
<body>
<DirectionProvider direction="rtl">{children}</DirectionProvider>
</body>
</html>
)
}添加字体
为了获得最佳的 RTL 体验,我们建议使用对目标语言有良好支持的字体。Noto 是非常适合的字体家族,它与 Inter 和 Geist 字体搭配良好。
import { Noto_Sans_Arabic } from "next/font/google"
import { DirectionProvider } from "@/components/ui/direction"
const fontSans = Noto_Sans_Arabic({
subsets: ["arabic"],
variable: "--font-sans",
})
export default function RootLayout({
children,
}: {
children: React.ReactNode
}) {
return (
<html lang="ar" dir="rtl" className={fontSans.variable}>
<body>
<DirectionProvider direction="rtl">{children}</DirectionProvider>
</body>
</html>
)
}对于其他语言,如希伯来语,你可以使用 Noto_Sans_Hebrew 字体。
添加组件
现在你可以开始向项目添加组件了。CLI 会帮你处理 RTL 支持。
pnpm dlx shadcn@latest add item