2016-03-31 14:17:09 +08:00
|
|
|
|
---
|
|
|
|
|
category: Components
|
2022-11-09 12:28:04 +08:00
|
|
|
|
group: 数据录入
|
2016-07-21 10:10:04 +08:00
|
|
|
|
title: Radio
|
2024-03-22 14:22:42 +08:00
|
|
|
|
subtitle: 单选框
|
|
|
|
|
description: 用于在多个备选项中选中单个状态。
|
2024-01-29 14:50:36 +08:00
|
|
|
|
cover: https://mdn.alipayobjects.com/huamei_7uahnr/afts/img/A*mrPVRope68wAAAAAAAAAAAAADrJ8AQ/original
|
|
|
|
|
coverDark: https://mdn.alipayobjects.com/huamei_7uahnr/afts/img/A*xPfTSphsiA0AAAAAAAAAAAAADrJ8AQ/original
|
2022-11-09 12:28:04 +08:00
|
|
|
|
demo:
|
|
|
|
|
cols: 2
|
2016-03-31 14:17:09 +08:00
|
|
|
|
---
|
2015-07-16 18:23:25 +08:00
|
|
|
|
|
|
|
|
|
## 何时使用
|
|
|
|
|
|
2015-07-16 22:40:49 +08:00
|
|
|
|
- 用于在多个备选项中选中单个状态。
|
|
|
|
|
- 和 Select 的区别是,Radio 所有选项默认可见,方便用户在比较中选择,因此选项不宜过多。
|
|
|
|
|
|
2022-11-09 12:28:04 +08:00
|
|
|
|
## 代码演示
|
|
|
|
|
|
2022-12-08 10:17:51 +08:00
|
|
|
|
<!-- prettier-ignore-start -->
|
2022-11-09 12:28:04 +08:00
|
|
|
|
<code src="./demo/basic.tsx">基本</code>
|
|
|
|
|
<code src="./demo/disabled.tsx">不可用</code>
|
|
|
|
|
<code src="./demo/radiogroup.tsx">单选组合</code>
|
|
|
|
|
<code src="./demo/radiogroup-more.tsx">Radio.Group 垂直</code>
|
2024-09-16 17:21:55 +08:00
|
|
|
|
<code src="./demo/radiogroup-block.tsx" version="5.21.0">Block 单选组合</code>
|
2022-11-09 12:28:04 +08:00
|
|
|
|
<code src="./demo/radiogroup-options.tsx">Radio.Group 组合 - 配置方式</code>
|
|
|
|
|
<code src="./demo/radiobutton.tsx">按钮样式</code>
|
|
|
|
|
<code src="./demo/radiogroup-with-name.tsx">单选组合 - 配合 name 使用</code>
|
|
|
|
|
<code src="./demo/size.tsx">大小</code>
|
|
|
|
|
<code src="./demo/radiobutton-solid.tsx">填底的按钮样式</code>
|
2022-12-06 23:14:30 +08:00
|
|
|
|
<code src="./demo/badge.tsx" debug>测试 Badge 的样式</code>
|
|
|
|
|
<code src="./demo/wireframe.tsx" debug>线框风格</code>
|
2023-06-05 16:16:43 +08:00
|
|
|
|
<code src="./demo/component-token.tsx" debug>组件 Token</code>
|
2024-12-03 19:07:28 +08:00
|
|
|
|
<code src="./demo/debug-upload.tsx" debug>Upload Debug</code>
|
2022-12-08 10:17:51 +08:00
|
|
|
|
<!-- prettier-ignore-end -->
|
2022-11-09 12:28:04 +08:00
|
|
|
|
|
2015-07-16 18:23:25 +08:00
|
|
|
|
## API
|
|
|
|
|
|
2023-08-08 18:27:48 +08:00
|
|
|
|
通用属性参考:[通用属性](/docs/react/common-props)
|
|
|
|
|
|
2020-02-26 16:09:22 +08:00
|
|
|
|
### Radio/Radio.Button
|
2015-07-17 16:06:46 +08:00
|
|
|
|
|
2022-12-08 10:17:51 +08:00
|
|
|
|
<!-- prettier-ignore -->
|
|
|
|
|
| 参数 | 说明 | 类型 | 默认值 |
|
|
|
|
|
| --- | --- | --- | --- |
|
|
|
|
|
| autoFocus | 自动获取焦点 | boolean | false |
|
|
|
|
|
| checked | 指定当前是否选中 | boolean | false |
|
|
|
|
|
| defaultChecked | 初始是否选中 | boolean | false |
|
|
|
|
|
| disabled | 禁用 Radio | boolean | false |
|
|
|
|
|
| value | 根据 value 进行比较,判断是否选中 | any | - |
|
2015-07-17 16:06:46 +08:00
|
|
|
|
|
2022-12-08 10:17:51 +08:00
|
|
|
|
### Radio.Group
|
2015-07-17 16:06:46 +08:00
|
|
|
|
|
2015-07-28 20:22:37 +08:00
|
|
|
|
单选框组合,用于包裹一组 `Radio`。
|
2015-07-20 22:36:49 +08:00
|
|
|
|
|
2022-12-08 10:17:51 +08:00
|
|
|
|
<!-- prettier-ignore -->
|
|
|
|
|
| 参数 | 说明 | 类型 | 默认值 | 版本 |
|
|
|
|
|
| --- | --- | --- | --- | --- |
|
2020-10-21 10:33:43 +08:00
|
|
|
|
| buttonStyle | RadioButton 的风格样式,目前有描边和填色两种风格 | `outline` \| `solid` | `outline` | | |
|
|
|
|
|
| defaultValue | 默认选中的值 | any | - | | |
|
2020-07-01 16:21:56 +08:00
|
|
|
|
| disabled | 禁选所有子单选器 | boolean | false | | |
|
2024-12-23 10:55:45 +08:00
|
|
|
|
| name | RadioGroup 下所有 `input[type="radio"]` 的 `name` 属性。若未设置,则将回退到随机生成的名称 | string | - | | |
|
2024-07-16 13:51:45 +08:00
|
|
|
|
| options | 以配置形式设置子元素 | string\[] \| number\[] \| Array<[CheckboxOptionType](#checkboxoptiontype)> | - | | |
|
2020-10-21 10:33:43 +08:00
|
|
|
|
| optionType | 用于设置 Radio `options` 类型 | `default` \| `button` | `default` | 4.4.0 | |
|
|
|
|
|
| size | 大小,只对按钮样式生效 | `large` \| `middle` \| `small` | - | | |
|
|
|
|
|
| value | 用于设置当前选中的值 | any | - | | |
|
2024-09-16 17:21:55 +08:00
|
|
|
|
| block | 将 RadioGroup 宽度调整为其父宽度的选项 | boolean | false | 5.21.0 | |
|
2020-10-21 10:33:43 +08:00
|
|
|
|
| onChange | 选项变化时的回调函数 | function(e:Event) | - | | |
|
2017-12-01 19:28:41 +08:00
|
|
|
|
|
2024-04-07 10:19:59 +08:00
|
|
|
|
### CheckboxOptionType
|
|
|
|
|
|
|
|
|
|
| Property | Description | Type | Default | Version |
|
|
|
|
|
| --- | --- | --- | --- | --- |
|
|
|
|
|
| label | 用于作为 Radio 选项展示的文本 | `string` | - | 4.4.0 |
|
|
|
|
|
| value | 关联 Radio 选项的值 | `string` \| `number` \| `boolean` | - | 4.4.0 |
|
|
|
|
|
| style | 应用到 Radio 选项的 style | `React.CSSProperties` | - | 4.4.0 |
|
|
|
|
|
| disabled | 指定 Radio 选项是否要禁用 | `boolean` | `false` | 4.4.0 |
|
|
|
|
|
| title | 添加 Title 属性值 | `string` | - | 4.4.0 |
|
|
|
|
|
| id | 添加 Radio Id 属性值 | `string` | - | 4.4.0 |
|
|
|
|
|
| onChange | 当 Radio Group 的值发送改变时触发 | `(e: CheckboxChangeEvent) => void;` | - | 4.4.0 |
|
|
|
|
|
| required | 指定 Radio 选项是否必填 | `boolean` | `false` | 4.4.0 |
|
|
|
|
|
|
2017-12-01 19:28:41 +08:00
|
|
|
|
## 方法
|
|
|
|
|
|
|
|
|
|
### Radio
|
|
|
|
|
|
2022-01-12 22:57:43 +08:00
|
|
|
|
| 名称 | 描述 |
|
|
|
|
|
| ------- | -------- |
|
|
|
|
|
| blur() | 移除焦点 |
|
2019-11-22 14:37:39 +08:00
|
|
|
|
| focus() | 获取焦点 |
|
2023-04-11 10:25:24 +08:00
|
|
|
|
|
2023-08-30 23:02:35 +08:00
|
|
|
|
## 主题变量(Design Token)
|
2023-04-11 10:25:24 +08:00
|
|
|
|
|
|
|
|
|
<ComponentTokenTable component="Radio"></ComponentTokenTable>
|