apps/docs/content/docs/cn/react/components/(navigation)/pagination.mdx
import { Pagination } from '@heroui/react';
<ComponentPreview name="pagination-basic" />
导入 Pagination 组件后,可通过点号访问各个子部分。
import { Pagination } from '@heroui/react';
export default () => (
<Pagination>
<Pagination.Summary>Showing 1-10 of 100 results</Pagination.Summary>
<Pagination.Content>
<Pagination.Item>
<Pagination.Previous>
<Pagination.PreviousIcon />
<span>Previous</span>
</Pagination.Previous>
</Pagination.Item>
<Pagination.Item>
<Pagination.Link isActive>1</Pagination.Link>
</Pagination.Item>
<Pagination.Item>
<Pagination.Ellipsis />
</Pagination.Item>
<Pagination.Item>
<Pagination.Link>10</Pagination.Link>
</Pagination.Item>
<Pagination.Item>
<Pagination.Next>
<span>Next</span>
<Pagination.NextIcon />
</Pagination.Next>
</Pagination.Item>
</Pagination.Content>
</Pagination>
);
<ComponentPreview name="pagination-sizes" />
<ComponentPreview name="pagination-with-ellipsis" />
<ComponentPreview name="pagination-simple-prev-next" />
<ComponentPreview name="pagination-with-summary" />
你可以通过为 PreviousIcon 与 NextIcon 传入自定义子节点来替换默认的 chevron 图标。
<ComponentPreview name="pagination-custom-icons" />
<ComponentPreview name="pagination-controlled" />
<ComponentPreview name="pagination-disabled" />
<RelatedComponents component="pagination" />你可以单独定制 Pagination 的各个子部分:
import { Pagination } from '@heroui/react';
function CustomPagination() {
return (
<Pagination className="gap-8">
<Pagination.Content className="gap-2">
<Pagination.Item>
<Pagination.Link className="rounded-md" isActive>1</Pagination.Link>
</Pagination.Item>
</Pagination.Content>
</Pagination>
);
}
要自定义 Pagination 的组件类,可使用 @layer components 指令。
了解更多。
@layer components {
.pagination {
@apply gap-8;
}
.pagination__link {
@apply rounded-md;
}
.pagination__summary {
@apply text-xs font-semibold;
}
}
HeroUI 遵循 BEM 方法论,以确保组件变体与状态可复用且易于自定义。
Pagination 使用以下 CSS 类(查看源码样式):
.pagination - 根导航容器(flex 布局).pagination__summary - 左侧信息文本容器.pagination__content - 分页项容器.pagination__item - 单个分页项包裹层.pagination__link - 页码按钮(ghost 按钮样式).pagination__link--nav - 导航按钮修饰符(Previous/Next).pagination__ellipsis - 省略号指示器.pagination--sm - 小尺寸变体.pagination--md - 中尺寸变体(默认).pagination--lg - 大尺寸变体组件同时支持 CSS 伪类与 data 属性,便于灵活定制:
[data-active="true"] 或 [aria-current="page"]:hover 或 [data-hovered="true"]:focus-visible 或 [data-focus-visible="true"]:disabled 或 [aria-disabled="true"]:active 或 [data-pressed="true"]| Prop | 类型 | 默认值 | 描述 |
|---|---|---|---|
size | "sm" | "md" | "lg" | "md" | 分页控件的尺寸 |
className | string | - | 额外的 CSS 类 |
children | ReactNode | - | 分页部件(Summary、Content 等) |
| Prop | 类型 | 默认值 | 描述 |
|---|---|---|---|
className | string | - | 额外的 CSS 类 |
children | ReactNode | - | 摘要内容(例如 "Showing 1-10 of 120") |
| Prop | 类型 | 默认值 | 描述 |
|---|---|---|---|
className | string | - | 额外的 CSS 类 |
children | ReactNode | - | 分页项 |
| Prop | 类型 | 默认值 | 描述 |
|---|---|---|---|
className | string | - | 额外的 CSS 类 |
children | ReactNode | - | 项内容(Link、Previous、Next 或 Ellipsis) |
| Prop | 类型 | 默认值 | 描述 |
|---|---|---|---|
isActive | boolean | false | 是否为当前页 |
isDisabled | boolean | false | 是否禁用链接 |
onPress | (e: PressEvent) => void | - | 按下事件处理函数(来自 React Aria) |
className | string | - | 额外的 CSS 类 |
children | ReactNode | - | 页码内容 |
| Prop | 类型 | 默认值 | 描述 |
|---|---|---|---|
isDisabled | boolean | false | 是否禁用按钮 |
onPress | (e: PressEvent) => void | - | 按下事件处理函数(来自 React Aria) |
className | string | - | 额外的 CSS 类 |
children | ReactNode | - | 按钮内容(可与 PreviousIcon/NextIcon 组合) |
| Prop | 类型 | 默认值 | 描述 |
|---|---|---|---|
className | string | - | 额外的 CSS 类 |
children | ReactNode | Default chevron SVG | 用于替换默认 chevron 的自定义图标 |
| Prop | 类型 | 默认值 | 描述 |
|---|---|---|---|
className | string | - | 额外的 CSS 类 |
Pagination 基于 React Aria 的 Button 原语实现所有可交互元素,并提供:
<nav> 元素,包含 aria-label="pagination" 与 role="navigation"aria-current="page" 标示活动页:focus-visible 显示焦点环aria-hidden="true",避免干扰屏幕阅读器isDisabled 向辅助技术正确传达禁用状态说明: Pagination 按钮请使用
onPress而不是onClick。React Aria 的onPress会规范化不同指针类型的按下行为,并提供开箱即用的无障碍改进。