- 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
import {
InputGroup,
InputGroupAddon,安装
pnpm dlx shadcn@latest add input-group
用法
import {
InputGroup,
InputGroupAddon,
InputGroupButton,
InputGroupInput,
InputGroupText,
InputGroupTextarea,
} from "@/components/ui/input-group"<InputGroup>
<InputGroupInput placeholder="Search..." />
<InputGroupAddon>
<SearchIcon />
</InputGroupAddon>
</InputGroup>对齐
使用 InputGroupAddon 上的 align 属性可以相对于输入框定位附加内容。
为了正确管理焦点,InputGroupAddon 应始终在 DOM 中位于
InputGroupInput 或 InputGroupTextarea 之后。使用 align 属性
可以在视觉上定位附加内容。
inline-start
使用 align="inline-start" 可将附加内容定位在输入框起始侧。这是默认值。
Icon positioned at the start.
import { Field, FieldDescription, FieldLabel } from "@/components/ui/field"
import {
InputGroup,inline-end
使用 align="inline-end" 可将附加内容定位在输入框末尾。
Icon positioned at the end.
import { Field, FieldDescription, FieldLabel } from "@/components/ui/field"
import {
InputGroup,block-start
使用 align="block-start" 可将附加内容定位在输入框上方。
Header positioned above the input.
Header positioned above the textarea.
import {
Field,
FieldDescription,block-end
使用 align="block-end" 可将附加内容定位在输入框下方。
Footer positioned below the input.
Footer positioned below the textarea.
import {
Field,
FieldDescription,示例
图标
import {
InputGroup,
InputGroupAddon,文本
import {
InputGroup,
InputGroupAddon,按钮
"use client"
import * as React from "react"Kbd
import {
InputGroup,
InputGroupAddon,下拉菜单
import {
DropdownMenu,
DropdownMenuContent,加载指示器
import {
InputGroup,
InputGroupAddon,文本域
import {
InputGroup,
InputGroupAddon,自定义输入
为你的自定义输入添加 data-slot="input-group-control" 属性,即可自动处理焦点状态。
下面是一个来自第三方库的可调整大小文本域示例。
"use client"
import {RTL
要在 shadcn/ui 中启用 RTL 支持,请参见 RTL 配置指南。
تذييل موضع أسفل منطقة النص.
"use client"
import * as React from "react"API 参考
InputGroup
用于包裹输入框和附加内容的主组件。
| Prop | Type | Default |
|---|---|---|
className | string |
<InputGroup>
<InputGroupInput />
<InputGroupAddon />
</InputGroup>InputGroupAddon
在输入框旁显示图标、文本、按钮或其他内容。
为了正确进行焦点导航,InputGroupAddon 组件应放在输入框之后。
通过 align 属性来定位附加内容。
| Prop | Type | Default |
|---|---|---|
align | "inline-start" | "inline-end" | "block-start" | "block-end" | "inline-start" |
className | string |
<InputGroupAddon align="inline-end">
<SearchIcon />
</InputGroupAddon>For <InputGroupInput />, use the inline-start or inline-end alignment. For <InputGroupTextarea />, use the block-start or block-end alignment.
The InputGroupAddon component can have multiple InputGroupButton components and icons.
<InputGroupAddon>
<InputGroupButton>Button</InputGroupButton>
<InputGroupButton>Button</InputGroupButton>
</InputGroupAddon>InputGroupButton
在输入组中显示按钮。
| Prop | Type | Default |
|---|---|---|
size | "xs" | "icon-xs" | "sm" | "icon-sm" | "xs" |
variant | "default" | "destructive" | "outline" | "secondary" | "ghost" | "link" | "ghost" |
className | string |
<InputGroupButton>Button</InputGroupButton>
<InputGroupButton size="icon-xs" aria-label="Copy">
<CopyIcon />
</InputGroupButton>InputGroupInput
Replacement for <Input /> when building input groups. This component has the input group styles pre-applied and uses the unified data-slot="input-group-control" for focus state handling.
| Prop | Type | Default |
|---|---|---|
className | string |
All other props are passed through to the underlying <Input /> component.
<InputGroup>
<InputGroupInput placeholder="Enter text..." />
<InputGroupAddon>
<SearchIcon />
</InputGroupAddon>
</InputGroup>InputGroupTextarea
Replacement for <Textarea /> when building input groups. This component has the textarea group styles pre-applied and uses the unified data-slot="input-group-control" for focus state handling.
| Prop | Type | Default |
|---|---|---|
className | string |
All other props are passed through to the underlying <Textarea /> component.
<InputGroup>
<InputGroupTextarea placeholder="Enter message..." />
<InputGroupAddon align="block-end">
<InputGroupButton>Send</InputGroupButton>
</InputGroupAddon>
</InputGroup>