2023-05-12 14:43:48 +08:00
|
|
|
---
|
|
|
|
category: Components
|
|
|
|
subtitle: 颜色选择器
|
|
|
|
title: ColorPicker
|
|
|
|
cover: https://mdn.alipayobjects.com/huamei_7uahnr/afts/img/A*PpY4RYNM8UcAAAAAAAAAAAAADrJ8AQ/original
|
|
|
|
coverDark: https://mdn.alipayobjects.com/huamei_7uahnr/afts/img/A*EHL-QYJofZsAAAAAAAAAAAAADrJ8AQ/original
|
2023-05-13 00:13:35 +08:00
|
|
|
tag: New
|
2023-05-12 14:43:48 +08:00
|
|
|
demo:
|
|
|
|
cols: 2
|
|
|
|
group:
|
|
|
|
title: 数据录入
|
|
|
|
---
|
|
|
|
|
2023-05-14 11:47:01 +08:00
|
|
|
提供颜色选取的组件,自 `5.5.0` 版本开始提供该组件。
|
2023-05-12 14:43:48 +08:00
|
|
|
|
|
|
|
## 何时使用
|
|
|
|
|
|
|
|
当用户需要自定义颜色选择的时候使用。
|
|
|
|
|
|
|
|
## 代码演示
|
|
|
|
|
|
|
|
<!-- prettier-ignore -->
|
|
|
|
<code src="./demo/base.tsx">基本使用</code>
|
2023-06-21 11:30:09 +08:00
|
|
|
<code src="./demo/size.tsx">触发器尺寸大小</code>
|
2023-05-16 13:49:59 +08:00
|
|
|
<code src="./demo/controlled.tsx">受控模式</code>
|
2023-07-10 13:37:43 +08:00
|
|
|
<code src="./demo/change-completed.tsx">颜色完成选择</code>
|
2023-06-19 19:29:39 +08:00
|
|
|
<code src="./demo/text-render.tsx">渲染触发器文本</code>
|
|
|
|
<code src="./demo/disabled.tsx">禁用</code>
|
2023-07-12 19:42:33 +08:00
|
|
|
<code src="./demo/disabled-alpha.tsx">禁用透明度</code>
|
2023-05-12 14:43:48 +08:00
|
|
|
<code src="./demo/allowClear.tsx">清除颜色</code>
|
|
|
|
<code src="./demo/trigger.tsx">自定义触发器</code>
|
2023-05-26 11:23:48 +08:00
|
|
|
<code src="./demo/trigger-event.tsx">自定义触发事件</code>
|
2023-05-12 14:43:48 +08:00
|
|
|
<code src="./demo/format.tsx">颜色编码</code>
|
|
|
|
<code src="./demo/presets.tsx">预设颜色</code>
|
2023-06-29 11:46:11 +08:00
|
|
|
<code src="./demo/panel-render.tsx">自定义面板</code>
|
2023-05-12 14:43:48 +08:00
|
|
|
<code src="./demo/pure-panel.tsx" debug>Pure Render</code>
|
|
|
|
|
|
|
|
## API
|
|
|
|
|
2023-08-08 18:27:48 +08:00
|
|
|
通用属性参考:[通用属性](/docs/react/common-props)
|
|
|
|
|
2023-05-12 14:43:48 +08:00
|
|
|
> 自 `antd@5.5.0` 版本开始提供该组件。
|
|
|
|
|
|
|
|
<!-- prettier-ignore -->
|
2023-06-19 19:29:39 +08:00
|
|
|
| 参数 | 说明 | 类型 | 默认值 | 版本 |
|
|
|
|
| :-- | :-- | :-- | :-- | :-- |
|
|
|
|
| allowClear | 允许清除选择的颜色 | boolean | false | |
|
2023-06-29 11:46:11 +08:00
|
|
|
| arrow | 配置弹出的箭头 | `boolean \| { pointAtCenter: boolean }` | true | |
|
2023-06-19 19:29:39 +08:00
|
|
|
| children | 颜色选择器的触发器 | React.ReactNode | - | |
|
2023-06-29 11:46:11 +08:00
|
|
|
| defaultValue | 颜色默认的值 | string \| `Color` | - | |
|
2023-09-05 18:42:40 +08:00
|
|
|
| defaultFormat | 颜色格式默认的值 | `rgb` \| `hex` \| `hsb` | - | 5.9.0 |
|
2023-06-19 19:29:39 +08:00
|
|
|
| disabled | 禁用颜色选择器 | boolean | - | |
|
2023-07-12 19:42:33 +08:00
|
|
|
| disabledAlpha | 禁用透明度 | boolean | - | 5.8.0 |
|
2023-06-19 19:29:39 +08:00
|
|
|
| destroyTooltipOnHide | 关闭后是否销毁弹窗 | `boolean` | false | 5.7.0 |
|
2023-06-29 11:46:11 +08:00
|
|
|
| format | 颜色格式 | `rgb` \| `hex` \| `hsb` | `hex` | |
|
|
|
|
| open | 是否显示弹出窗口 | boolean | - | |
|
2023-11-03 16:49:22 +08:00
|
|
|
| presets | 预设的颜色 | `{ label: ReactNode, colors: Array<string \| Color>, defaultOpen?: boolean }[]` | - | `defaultOpen: 5.11.0` |
|
2023-06-29 11:46:11 +08:00
|
|
|
| placement | 弹出窗口的位置 | `top` \| `topLeft` \| `topRight` \| `bottom` \| `bottomLeft` \| `bottomRight` | `bottomLeft` | |
|
|
|
|
| panelRender | 自定义渲染面板 | `(panel: React.ReactNode, extra: { components: { Picker: FC; Presets: FC } }) => React.ReactNode` | - | 5.7.0 |
|
2023-06-19 19:29:39 +08:00
|
|
|
| showText | 显示颜色文本 | boolean \| `(color: Color) => React.ReactNode` | - | 5.7.0 |
|
2023-06-21 11:30:09 +08:00
|
|
|
| size | 设置触发器大小 | `large` \| `middle` \| `small` | `middle` | 5.7.0 |
|
2023-06-29 11:46:11 +08:00
|
|
|
| trigger | 颜色选择器的触发模式 | `hover` \| `click` | `click` | |
|
|
|
|
| value | 颜色的值 | string \| `Color` | - | |
|
2023-06-19 19:29:39 +08:00
|
|
|
| onChange | 颜色变化的回调 | `(value: Color, hex: string) => void` | - | |
|
2023-07-10 13:37:43 +08:00
|
|
|
| onChangeComplete | 颜色选择完成的回调 | `(value: Color) => void` | - | 5.7.0 |
|
2023-06-19 19:29:39 +08:00
|
|
|
| onFormatChange | 颜色格式变化的回调 | `(format: 'hex' \| 'rgb' \| 'hsb') => void` | - | |
|
|
|
|
| onOpenChange | 当 `open` 被改变时的回调 | `(open: boolean) => void` | - | |
|
|
|
|
| onClear | 清除的回调 | `() => void` | - | 5.6.0 |
|
2023-05-12 14:43:48 +08:00
|
|
|
|
|
|
|
### Color
|
|
|
|
|
|
|
|
<!-- prettier-ignore -->
|
|
|
|
| 参数 | 说明 | 类型 | 默认值 |
|
|
|
|
| :-- | :-- | :-- | :-- |
|
2023-06-01 14:36:58 +08:00
|
|
|
| toHex | 转换成 `hex` 格式字符,返回格式如:`1677ff` | `() => string` | - |
|
|
|
|
| toHexString | 转换成 `hex` 格式颜色字符串,返回格式如:`#1677ff` | `() => string` | - |
|
2023-05-12 14:43:48 +08:00
|
|
|
| toHsb | 转换成 `hsb` 对象 | `() => ({ h: number, s: number, b: number, a number })` | - |
|
2023-06-01 14:36:58 +08:00
|
|
|
| toHsbString | 转换成 `hsb` 格式颜色字符串,返回格式如:`hsb(215, 91%, 100%)` | `() => string` | - |
|
2023-05-12 14:43:48 +08:00
|
|
|
| toRgb | 转换成 `rgb` 对象 | `() => ({ r: number, g: number, b: number, a number })` | - |
|
2023-06-01 14:36:58 +08:00
|
|
|
| toRgbString | 转换成 `rgb` 格式颜色字符串,返回格式如:`rgb(22, 119, 255)` | `() => string` | - |
|
2023-05-12 14:43:48 +08:00
|
|
|
|
|
|
|
## FAQ
|
|
|
|
|
|
|
|
### 关于颜色赋值的问题
|
|
|
|
|
|
|
|
颜色选择器的值同时支持字符串色值和选择器生成的 `Color` 对象,但由于不同格式的颜色字符串互相转换会有精度误差问题,所以受控场景推荐使用选择器生成的 `Color` 对象来进行赋值操作,这样可以避免精度问题,保证取值是精准的,选择器也可以按照预期工作。
|