logoAnt Design

⌘ K
  • 设计
  • 研发
  • 组件
  • 博客
  • 资源
  • 国内镜像
6.0.0-alpha.3
  • 组件总览
  • 更新日志
    v6.0.0-alpha.3
  • 通用
    • Button按钮
    • FloatButton悬浮按钮
      5.0.0
    • Icon图标
    • Typography排版
  • 布局
    • Divider分割线
    • Flex弹性布局
      5.10.0
    • Grid栅格
    • Layout布局
    • Masonry瀑布流
      6.0.0
    • Space间距
    • Splitter分隔面板
      5.21.0
  • 导航
    • Anchor锚点
    • Breadcrumb面包屑
    • Dropdown下拉菜单
    • Menu导航菜单
    • Pagination分页
    • Steps步骤条
    • Tabs标签页
  • 数据录入
    • AutoComplete自动完成
    • Cascader级联选择
    • Checkbox多选框
    • ColorPicker颜色选择器
      5.5.0
    • DatePicker日期选择框
    • Form表单
    • Input输入框
    • InputNumber数字输入框
    • Mentions提及
    • Radio单选框
    • Rate评分
    • Select选择器
    • Slider滑动输入条
    • Switch开关
    • TimePicker时间选择框
    • Transfer穿梭框
    • TreeSelect树选择
    • Upload上传
  • 数据展示
    • Avatar头像
    • Badge徽标数
    • Calendar日历
    • Card卡片
    • Carousel走马灯
    • Collapse折叠面板
    • Descriptions描述列表
    • Empty空状态
    • Image图片
    • List列表
      废弃
    • Popover气泡卡片
    • QRCode二维码
      5.1.0
    • Segmented分段控制器
    • Statistic统计数值
    • Table表格
    • Tag标签
    • Timeline时间轴
    • Tooltip文字提示
    • Tour漫游式引导
      5.0.0
    • Tree树形控件
  • 反馈
    • Alert警告提示
    • Drawer抽屉
    • Message全局提示
    • Modal对话框
    • Notification通知提醒框
    • Popconfirm气泡确认框
    • Progress进度条
    • Result结果
    • Skeleton骨架屏
    • Spin加载中
    • Watermark水印
      5.1.0
  • 其他
    • Affix固钉
    • App包裹组件
      5.1.0
    • ConfigProvider全局化配置
    • Util工具类
何时使用
代码演示
基本
垂直方向
Block 分段选择器
胶囊形状
不可用
受控模式
自定义渲染
动态数据
三种大小
设置图标
只设置图标
配合 name 使用
自定义语义结构的样式和类
API
Segmented
SegmentedItemType
Semantic DOM
主题变量(Design Token)

Segmented
分段控制器

用于展示多个选项并允许用户选择其中单个选项。
使用import { Segmented } from "antd";
反馈
components/segmented提交问题待解决
文档
编辑此页
文档贡献者
QRCode二维码Statistic统计数值

相关资源

Ant Design X
Ant Design Charts
Ant Design Pro
Pro Components
Ant Design Mobile
Ant Design Mini
Ant Design Web3
Ant Design Landing-首页模板集
Scaffolds-脚手架市场
Umi-React 应用开发框架
dumi-组件/文档研发工具
qiankun-微前端框架
Ant Motion-设计动效
国内镜像站点 🇨🇳

社区

Awesome Ant Design
Medium
X
yuque logoAnt Design 语雀专栏
Ant Design 知乎专栏
体验科技专栏
seeconf logoSEE Conf-蚂蚁体验科技大会
加入我们

帮助

GitHub
更新日志
常见问题
报告 Bug
议题
讨论区
StackOverflow
SegmentFault

Ant XTech logo更多产品

yuque logo语雀-构建你的数字花园
AntV logoAntV-数据可视化解决方案
Egg logoEgg-企业级 Node.js 框架
Kitchen logoKitchen-Sketch 工具集
Galacean logoGalacean-互动图形解决方案
WeaveFox logoWeaveFox-前端智能研发
xtech logo蚂蚁体验科技
主题编辑器
Made with ❤ by
蚂蚁集团和 Ant Design 开源社区
loading

自 antd@4.20.0 版本开始提供该组件。

何时使用

  • 用于展示多个选项并允许用户选择其中单个选项;
  • 当切换选中选项时,关联区域的内容会发生变化。

代码演示

API

通用属性参考:通用属性

自 antd@4.20.0 版本开始提供该组件。

Segmented

参数说明类型默认值版本
block将宽度调整为父元素宽度的选项booleanfalse
classNames用于自定义 Segmented 组件内部各语义化结构的 class,支持对象或函数Record<SemanticDOM, string> | (info: { props }) => Record<SemanticDOM, string>-
defaultValue默认选中的值string | number
disabled是否禁用booleanfalse
onChange选项变化时的回调函数function(value: string | number)
options数据化配置选项内容string[] | number[] | SegmentedItemType[][]
orientation排列方向horizontal | verticalhorizontal
size控件尺寸large | middle | smallmiddle
styles用于自定义 Segmented 组件内部各语义化结构的行内 style,支持对象或函数Record<SemanticDOM , CSSProperties> | (info: { props }) => Record<SemanticDOM , CSSProperties>-
vertical排列方向,与 orientation 同时存在,以 orientation 优先booleanfalse5.21.0
value当前选中的值string | number
shape形状default | rounddefault5.24.0
nameSegmented 下所有 input[type="radio"] 的 name 属性。若未设置,则将回退到随机生成的名称string5.23.0

SegmentedItemType

属性描述类型默认值版本
className自定义类名string-
disabled分段项的禁用状态booleanfalse
icon分段项的显示图标ReactNode-
label分段项的显示文本ReactNode-
tooltip分段项的工具提示string | TooltipProps-
value分段项的值string | number-

Semantic DOM

  • root
    6.0.0
    根元素,设置行内块布局、内边距、背景色、圆角、过渡动画和容器样式
  • item
    6.0.0
    选项元素,设置相对定位、文本对齐、光标样式、过渡动画、选中态背景色和悬停态样式
  • label
    6.0.0
    标签内容元素,设置最小高度、行高、内边距、文本省略和内容布局样式
  • icon
    6.0.0
    图标元素,设置图标的尺寸、颜色和与文本的间距样式

主题变量(Design Token)

组件 Token如何定制?
Token 名称描述类型默认值
itemActiveBg选项激活态背景颜色stringrgba(0,0,0,0.15)
itemColor选项文本颜色stringrgba(0,0,0,0.65)
itemHoverBg选项悬浮态背景颜色stringrgba(0,0,0,0.06)
itemHoverColor选项悬浮态文本颜色stringrgba(0,0,0,0.88)
itemSelectedBg选项选中时背景颜色string#ffffff
itemSelectedColor选项选中时文字颜色stringrgba(0,0,0,0.88)
trackBgSegmented 控件容器背景色string#f5f5f5
trackPaddingSegmented 控件容器的 paddingstring | number2
全局 Token如何定制?
基本

最简单的用法。

CodeSandbox Icon
Hitu Icon
codepen icon
External Link Icon
Expand Icon
Block 分段选择器

block 属性使其适合父元素宽度。

CodeSandbox Icon
Hitu Icon
codepen icon
External Link Icon
Expand Icon
不可用

Segmented 不可用。

CodeSandbox Icon
Hitu Icon
codepen icon
External Link Icon
Expand Icon
自定义渲染

自定义渲染每一个 Segmented Item。

CodeSandbox Icon
codepen icon
External Link Icon
Expand Icon
三种大小

我们为 <Segmented /> 组件定义了三种尺寸(大、默认、小),高度分别为 40px、32px 和 24px。

CodeSandbox Icon
codepen icon
External Link Icon
Expand Icon
只设置图标

在 Segmented Item 选项中只设置 Icon。

CodeSandbox Icon
Hitu Icon
codepen icon
External Link Icon
Expand Icon
自定义语义结构的样式和类

通过 classNames 和 styles 传入对象/函数可以自定义 Segmented 的语义化结构样式。

6.0.0
垂直方向

垂直方向。

CodeSandbox Icon
Hitu Icon
codepen icon
External Link Icon
Expand Icon
5.21.0
胶囊形状

胶囊型的 Segmented。

CodeSandbox Icon
codepen icon
External Link Icon
Expand Icon
5.24.0
受控模式

受控的 Segmented。

CodeSandbox Icon
Hitu Icon
codepen icon
External Link Icon
Expand Icon
动态数据

动态加载数据。

CodeSandbox Icon
Hitu Icon
codepen icon
External Link Icon
Expand Icon
设置图标

给 Segmented Item 设置 Icon。

CodeSandbox Icon
Hitu Icon
codepen icon
External Link Icon
Expand Icon
配合 name 使用

可以为 Segmented 配置 name 参数,为组合内的 input 元素赋予相同的 name 属性,使浏览器把 Segmented 下的 input 真正看作是一组(例如可以通过方向键始终在同一组内更改选项)。

CodeSandbox Icon
Hitu Icon
codepen icon
External Link Icon
Expand Icon
5.23.0
Hitu Icon
Hitu Icon
CodeSandbox Icon
Hitu Icon
codepen icon
External Link Icon
Expand Icon
Hitu Icon