* feat(button): add antd preset colors * chore(button): add colors to docs * test(button): add tests for colors * refactor: remove LiteralUnion * test: add const to colors * refactor(button): import from preset colors * chore(button): update docs * test(button): test with preset colors * test(button): import from relative path * fix(button): color * fix(button): add missing box shadow * test(button): merge preset colors and variants test case * refactor(button): use light color as box shadow * refactor(button): set hover color to 5 * docs(button): update doc * docs(button): update doc --------- Co-authored-by: ice <49827327+coding-ice@users.noreply.github.com> Co-authored-by: lijianan <574980606@qq.com>
5.6 KiB
category | title | description | cover | coverDark | demo | group | ||||||
---|---|---|---|---|---|---|---|---|---|---|---|---|
Components | Button | To trigger an operation. | https://mdn.alipayobjects.com/huamei_7uahnr/afts/img/A*7va7RKs3YzIAAAAAAAAAAAAADrJ8AQ/original | https://mdn.alipayobjects.com/huamei_7uahnr/afts/img/A*3T4cRqxH9-8AAAAAAAAAAAAADrJ8AQ/original |
|
|
When To Use
A button means an operation (or a series of operations). Clicking a button will trigger its corresponding business logic.
In Ant Design we provide 5 types of button.
- Primary button: used for the main action, there can be at most one primary button in a section.
- Default button: used for a series of actions without priority.
- Dashed button: commonly used for adding more actions.
- Text button: used for the most secondary action.
- Link button: used for external links.
And 4 other properties additionally.
danger
: used for actions of risk, like deletion or authorization.ghost
: used in situations with complex background, home pages usually.disabled
: used when actions are not available.loading
: adds a loading spinner in button, avoids multiple submits too.
Examples
Syntactic sugar
Color & Variant
Debug Color & Variant
Icon
Icon Position
Debug Icon
Debug Block
Size
Disabled
Loading
Multiple Buttons
Ghost Button
Danger Buttons
Block Button
Deprecated Button Group
Loading style bug
Component Token
Gradient Button
API
Common props ref:Common props
Different button styles generated by setting Button properties. The recommended order is: type
-> shape
-> size
-> loading
-> disabled
.
Property | Description | Type | Default | Version |
---|---|---|---|---|
autoInsertSpace | We add a space between two Chinese characters by default, which removed by setting autoInsertSpace to false . |
boolean | true |
5.17.0 |
block | Option to fit button width to its parent width | boolean | false | |
classNames | Semantic DOM class | Record<SemanticDOM, string> | - | 5.4.0 |
color | Set button color | default | primary | danger | PresetColors |
- | default , primary and danger : 5.21.0, PresetColors : 5.23.0 |
danger | Syntactic sugar. Set the danger status of button. will follow color if provided |
boolean | false | |
disabled | Disabled state of button | boolean | false | |
ghost | Make background transparent and invert text and border colors | boolean | false | |
href | Redirect url of link button | string | - | |
htmlType | Set the original html type of button , see: MDN |
submit | reset | button |
button |
|
icon | Set the icon component of button | ReactNode | - | |
iconPosition | Set the icon position of button | start | end |
start |
5.17.0 |
loading | Set the loading status of button | boolean | { delay: number, icon: ReactNode } | false | icon: 5.23.0 |
shape | Can be used to set button shape | default | circle | round |
default |
|
size | Set the size of button | large | middle | small |
middle |
|
styles | Semantic DOM style | Record<SemanticDOM, CSSProperties> | - | 5.4.0 |
target | Same as target attribute of a, works when href is specified | string | - | |
type | Syntactic sugar. Set button type. Will follow variant & color if provided |
primary | dashed | link | text | default |
default |
|
onClick | Set the handler to handle click event |
(event: React.MouseEvent<HTMLElement, MouseEvent>) => void | - | |
variant | Set button variant | outlined | dashed | solid | filled | text | link |
- | 5.21.0 |
It accepts all props which native buttons support.
PresetColors
type PresetColors = 'blue' | 'purple' | 'cyan' | 'green' | 'magenta' | 'pink' | 'red' | 'orange' | 'yellow' | 'volcano' | 'geekblue' | 'lime' | 'gold';
Semantic DOM
Design Token
FAQ
How to choose type and color & variant?
Type is essentially syntactic sugar for colors and variants. It internally provides a set of mapping relationships between colors and variants for the type. If both exist at the same time, the colors and variants will be used first.
<Button type="primary">click</Button>
Equivalent
<Button color="primary" variant="solid">
click
</Button>
How to close the click wave effect?
If you don't need this feature, you can set disabled
of wave
in ConfigProvider as true
.
<ConfigProvider wave={{ disabled: true }}>
<Button>click</Button>
</ConfigProvider>