ant-design/components/button/index.en-US.md
Oyster Lee 6b98f84c62
feat(Button): support color from Antd's colors (#51550)
* 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>
2024-12-09 14:27:07 +08:00

5.6 KiB
Raw Blame History

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
cols
2
title order
General 1

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 refCommon 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>