2016-03-31 14:17:09 +08:00
|
|
|
|
---
|
|
|
|
|
category: Components
|
2016-04-22 14:52:19 +08:00
|
|
|
|
title: Button
|
|
|
|
|
subtitle: 按钮
|
2024-03-22 14:22:42 +08:00
|
|
|
|
description: 按钮用于开始一个即时操作。
|
2024-01-29 14:50:36 +08:00
|
|
|
|
cover: https://mdn.alipayobjects.com/huamei_7uahnr/afts/img/A*7va7RKs3YzIAAAAAAAAAAAAADrJ8AQ/original
|
|
|
|
|
coverDark: https://mdn.alipayobjects.com/huamei_7uahnr/afts/img/A*3T4cRqxH9-8AAAAAAAAAAAAADrJ8AQ/original
|
2022-11-09 12:28:04 +08:00
|
|
|
|
demo:
|
|
|
|
|
cols: 2
|
|
|
|
|
group:
|
|
|
|
|
title: 通用
|
|
|
|
|
order: 1
|
2016-03-31 14:17:09 +08:00
|
|
|
|
---
|
2015-05-12 17:50:03 +08:00
|
|
|
|
|
2015-05-27 15:43:29 +08:00
|
|
|
|
## 何时使用
|
2015-05-15 18:03:27 +08:00
|
|
|
|
|
2015-06-17 17:43:04 +08:00
|
|
|
|
标记了一个(或封装一组)操作命令,响应用户点击行为,触发相应的业务逻辑。
|
2015-06-14 17:54:08 +08:00
|
|
|
|
|
2020-07-21 10:07:38 +08:00
|
|
|
|
在 Ant Design 中我们提供了五种按钮。
|
2020-01-03 15:22:16 +08:00
|
|
|
|
|
|
|
|
|
- 主按钮:用于主行动点,一个操作区域只能有一个主按钮。
|
|
|
|
|
- 默认按钮:用于没有主次之分的一组行动点。
|
|
|
|
|
- 虚线按钮:常用于添加操作。
|
2020-05-06 10:15:33 +08:00
|
|
|
|
- 文本按钮:用于最次级的行动点。
|
2021-09-28 10:38:37 +08:00
|
|
|
|
- 链接按钮:一般用于链接,即导航至某位置。
|
2020-01-03 15:22:16 +08:00
|
|
|
|
|
2020-01-03 15:30:05 +08:00
|
|
|
|
以及四种状态属性与上面配合使用。
|
|
|
|
|
|
2020-01-03 15:22:16 +08:00
|
|
|
|
- 危险:删除/移动/修改权限等危险操作,一般需要二次确认。
|
|
|
|
|
- 幽灵:用于背景色比较复杂的地方,常用在首页/产品页等展示场景。
|
|
|
|
|
- 禁用:行动点不可用的时候,一般需要文案解释。
|
|
|
|
|
- 加载中:用于异步操作等待反馈的时候,也可以避免多次提交。
|
|
|
|
|
|
2021-09-28 10:38:37 +08:00
|
|
|
|
[完整设计指南](https://ant.design/docs/spec/buttons-cn)
|
|
|
|
|
|
2022-11-09 12:28:04 +08:00
|
|
|
|
## 代码演示
|
|
|
|
|
|
2022-11-17 17:31:26 +08:00
|
|
|
|
<!-- prettier-ignore -->
|
2022-11-09 12:28:04 +08:00
|
|
|
|
<code src="./demo/basic.tsx">按钮类型</code>
|
|
|
|
|
<code src="./demo/icon.tsx">图标按钮</code>
|
2022-11-17 13:20:58 +08:00
|
|
|
|
<code src="./demo/debug-icon.tsx" debug>调试图标按钮</code>
|
2023-01-06 09:46:00 +08:00
|
|
|
|
<code src="./demo/debug-block.tsx" debug>调试按钮block属性</code>
|
2022-11-09 12:28:04 +08:00
|
|
|
|
<code src="./demo/size.tsx">按钮尺寸</code>
|
|
|
|
|
<code src="./demo/disabled.tsx">不可用状态</code>
|
|
|
|
|
<code src="./demo/loading.tsx">加载中状态</code>
|
|
|
|
|
<code src="./demo/multiple.tsx">多个按钮组合</code>
|
|
|
|
|
<code src="./demo/ghost.tsx">幽灵按钮</code>
|
|
|
|
|
<code src="./demo/danger.tsx">危险按钮</code>
|
|
|
|
|
<code src="./demo/block.tsx">Block 按钮</code>
|
|
|
|
|
<code src="./demo/legacy-group.tsx" debug>废弃的 Block 组</code>
|
|
|
|
|
<code src="./demo/chinese-chars-loading.tsx" debug>加载中状态 bug 还原</code>
|
2023-08-08 14:03:31 +08:00
|
|
|
|
<code src="./demo/component-token.tsx" debug>组件 Token</code>
|
2024-04-07 19:14:56 +08:00
|
|
|
|
<code src="./demo/linear-gradient.tsx">渐变按钮</code>
|
2022-11-09 12:28:04 +08:00
|
|
|
|
|
2015-10-29 23:17:25 +08:00
|
|
|
|
## API
|
2015-06-05 20:26:41 +08:00
|
|
|
|
|
2023-08-08 18:27:48 +08:00
|
|
|
|
通用属性参考:[通用属性](/docs/react/common-props)
|
|
|
|
|
|
2019-02-17 23:07:02 +08:00
|
|
|
|
通过设置 Button 的属性来产生不同的按钮样式,推荐顺序为:`type` -> `shape` -> `size` -> `loading` -> `disabled`。
|
2015-09-27 16:30:35 +08:00
|
|
|
|
|
2016-03-25 18:13:51 +08:00
|
|
|
|
按钮的属性说明如下:
|
2015-09-27 16:30:35 +08:00
|
|
|
|
|
2019-07-11 14:14:33 +08:00
|
|
|
|
| 属性 | 说明 | 类型 | 默认值 | 版本 |
|
|
|
|
|
| --- | --- | --- | --- | --- |
|
2020-08-07 15:50:53 +08:00
|
|
|
|
| block | 将按钮宽度调整为其父宽度的选项 | boolean | false | |
|
2024-02-05 11:45:42 +08:00
|
|
|
|
| classNames | 语义化结构 class | [Record<SemanticDOM, string>](#semantic-dom) | - | 5.4.0 |
|
2020-08-07 15:50:53 +08:00
|
|
|
|
| danger | 设置危险按钮 | boolean | false | |
|
2022-12-05 21:01:30 +08:00
|
|
|
|
| disabled | 设置按钮失效状态 | boolean | false | |
|
2019-11-21 10:16:58 +08:00
|
|
|
|
| ghost | 幽灵属性,使按钮背景透明 | boolean | false | |
|
2019-07-11 14:14:33 +08:00
|
|
|
|
| href | 点击跳转的地址,指定此属性 button 的行为和 a 链接一致 | string | - | |
|
|
|
|
|
| htmlType | 设置 `button` 原生的 `type` 值,可选值请参考 [HTML 标准](https://developer.mozilla.org/en-US/docs/Web/HTML/Element/button#attr-type) | string | `button` | |
|
2019-08-13 14:07:17 +08:00
|
|
|
|
| icon | 设置按钮的图标组件 | ReactNode | - | |
|
2020-06-17 23:18:14 +08:00
|
|
|
|
| loading | 设置按钮载入状态 | boolean \| { delay: number } | false | |
|
2023-02-01 10:11:53 +08:00
|
|
|
|
| shape | 设置按钮形状 | `default` \| `circle` \| `round` | `default` | |
|
2020-10-22 08:33:20 +08:00
|
|
|
|
| size | 设置按钮大小 | `large` \| `middle` \| `small` | `middle` | |
|
2024-02-05 11:45:42 +08:00
|
|
|
|
| styles | 语义化结构 style | [Record<SemanticDOM, CSSProperties>](#semantic-dom) | - | 5.4.0 |
|
2019-07-11 14:14:33 +08:00
|
|
|
|
| target | 相当于 a 链接的 target 属性,href 存在时生效 | string | - | |
|
2023-07-14 17:05:59 +08:00
|
|
|
|
| type | 设置按钮类型 | `primary` \| `dashed` \| `link` \| `text` \| `default` | `default` | |
|
2022-12-15 17:48:29 +08:00
|
|
|
|
| onClick | 点击按钮时的回调 | (event: MouseEvent) => void | - | |
|
2015-09-27 16:30:35 +08:00
|
|
|
|
|
2018-10-28 20:57:23 +08:00
|
|
|
|
支持原生 button 的其他所有属性。
|
|
|
|
|
|
2024-02-05 11:45:42 +08:00
|
|
|
|
## Semantic DOM
|
2023-04-11 11:37:31 +08:00
|
|
|
|
|
2024-02-05 11:45:42 +08:00
|
|
|
|
<code src="./demo/_semantic.tsx" simplify="true"></code>
|
2023-04-11 11:37:31 +08:00
|
|
|
|
|
2023-08-30 23:02:35 +08:00
|
|
|
|
## 主题变量(Design Token)
|
2023-03-12 14:13:03 +08:00
|
|
|
|
|
|
|
|
|
<ComponentTokenTable component="Button"></ComponentTokenTable>
|
|
|
|
|
|
2019-01-10 11:47:11 +08:00
|
|
|
|
## FAQ
|
|
|
|
|
|
2024-03-26 18:20:28 +08:00
|
|
|
|
### 如何关闭点击波纹效果?
|
|
|
|
|
|
|
|
|
|
如果你不需要这个特性,可以设置 [ConfigProvider](/components/config-provider-cn#api) 的 `wave` 的 `disabled` 为 `true`。
|
|
|
|
|
|
|
|
|
|
```jsx
|
|
|
|
|
<ConfigProvider wave={{ disabled: true }}>
|
|
|
|
|
<Button>click</Button>
|
|
|
|
|
</ConfigProvider>
|
|
|
|
|
```
|
|
|
|
|
|
2019-06-21 00:28:33 +08:00
|
|
|
|
### 如何移除两个汉字之间的空格?
|
|
|
|
|
|
2024-03-26 18:20:28 +08:00
|
|
|
|
根据 Ant Design 设计规范要求,我们会在按钮内(文本按钮和链接按钮除外)只有两个汉字时自动添加空格,如果你不需要这个特性,可以设置 [ConfigProvider](/components/config-provider-cn#api) 的 `autoInsertSpaceInButton` 为 `false`。
|
2019-01-10 11:47:11 +08:00
|
|
|
|
|
2024-03-26 18:20:28 +08:00
|
|
|
|
```jsx
|
2023-11-01 10:15:29 +08:00
|
|
|
|
<ConfigProvider autoInsertSpaceInButton={false}>
|
|
|
|
|
<Button>按钮</Button>
|
|
|
|
|
</ConfigProvider>
|
|
|
|
|
```
|
|
|
|
|
|
2023-07-21 17:14:54 +08:00
|
|
|
|
<img src="https://gw.alipayobjects.com/zos/antfincdn/MY%26THAPZrW/38f06cb9-293a-4b42-b183-9f443e79ffea.png" style="box-shadow: none; margin: 0" width="100px" height="64px" alt="移除两个汉字之间的空格" />
|
2019-01-10 11:47:11 +08:00
|
|
|
|
|
2016-04-22 14:52:19 +08:00
|
|
|
|
<style>
|
2022-11-17 13:20:58 +08:00
|
|
|
|
.site-button-ghost-wrapper {
|
2022-11-17 23:19:28 +08:00
|
|
|
|
padding: 16px;
|
2022-11-17 13:20:58 +08:00
|
|
|
|
background: rgb(190, 200, 200);
|
2020-04-27 21:40:52 +08:00
|
|
|
|
}
|
2016-04-22 14:52:19 +08:00
|
|
|
|
</style>
|
2020-03-23 12:28:41 +08:00
|
|
|
|
|
|
|
|
|
## 设计指引
|
|
|
|
|
|
|
|
|
|
- [我的按钮究竟该放哪儿!?| Ant Design 4.0 系列分享](https://zhuanlan.zhihu.com/p/109644406)
|