2016-03-31 14:17:09 +08:00
|
|
|
|
---
|
|
|
|
|
category: Components
|
2016-09-21 11:28:38 +08:00
|
|
|
|
subtitle: 文字提示
|
2022-11-09 12:28:04 +08:00
|
|
|
|
group: 数据展示
|
2016-09-21 11:28:38 +08:00
|
|
|
|
title: Tooltip
|
2022-11-30 20:14:41 +08:00
|
|
|
|
cover: https://mdn.alipayobjects.com/huamei_7uahnr/afts/img/A*3u9eSZO_4c0AAAAAAAAAAAAADrJ8AQ/original
|
2023-02-09 22:17:31 +08:00
|
|
|
|
coverDark: https://mdn.alipayobjects.com/huamei_7uahnr/afts/img/A*gwrhTozoTC4AAAAAAAAAAAAADrJ8AQ/original
|
2022-11-09 12:28:04 +08:00
|
|
|
|
demo:
|
|
|
|
|
cols: 2
|
2016-03-31 14:17:09 +08:00
|
|
|
|
---
|
2015-05-27 15:43:29 +08:00
|
|
|
|
|
2015-06-03 17:08:43 +08:00
|
|
|
|
简单的文字提示气泡框。
|
2015-05-27 15:43:29 +08:00
|
|
|
|
|
2015-06-03 17:08:43 +08:00
|
|
|
|
## 何时使用
|
2015-05-27 15:43:29 +08:00
|
|
|
|
|
2015-06-03 17:48:52 +08:00
|
|
|
|
鼠标移入则显示提示,移出消失,气泡浮层不承载复杂文本和操作。
|
|
|
|
|
|
2020-11-08 15:04:02 +08:00
|
|
|
|
可用来代替系统默认的 `title` 提示,提供一个 `按钮/文字/操作` 的文案解释。
|
2015-06-03 17:52:44 +08:00
|
|
|
|
|
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/placement.tsx">位置</code>
|
2023-01-19 11:21:05 +08:00
|
|
|
|
<code src="./demo/arrow.tsx">箭头展示</code>
|
2023-02-15 10:21:28 +08:00
|
|
|
|
<code src="./demo/shift.tsx" iframe="200">贴边偏移</code>
|
2022-11-09 12:28:04 +08:00
|
|
|
|
<code src="./demo/auto-adjust-overflow.tsx" debug>自动调整位置</code>
|
|
|
|
|
<code src="./demo/destroy-tooltip-on-hide.tsx" debug>隐藏后销毁</code>
|
|
|
|
|
<code src="./demo/colorful.tsx">多彩文字提示</code>
|
|
|
|
|
<code src="./demo/render-panel.tsx" debug>_InternalPanelDoNotUseOrYouWillBeFired</code>
|
2023-03-05 17:51:19 +08:00
|
|
|
|
<code src="./demo/debug.tsx" debug>Debug</code>
|
2023-07-28 17:39:38 +08:00
|
|
|
|
<code src="./demo/disabled.tsx" debug>禁用</code>
|
2022-11-09 12:28:04 +08:00
|
|
|
|
|
2015-06-03 17:52:44 +08:00
|
|
|
|
## API
|
|
|
|
|
|
2021-06-25 11:04:00 +08:00
|
|
|
|
| 参数 | 说明 | 类型 | 默认值 |
|
|
|
|
|
| ----- | -------- | ---------------------------- | ------ |
|
|
|
|
|
| title | 提示文字 | ReactNode \| () => ReactNode | - |
|
2016-12-22 12:00:57 +08:00
|
|
|
|
|
|
|
|
|
### 共同的 API
|
|
|
|
|
|
|
|
|
|
以下 API 为 Tooltip、Popconfirm、Popover 共享的 API。
|
|
|
|
|
|
2020-05-07 13:57:50 +08:00
|
|
|
|
| 参数 | 说明 | 类型 | 默认值 | 版本 |
|
|
|
|
|
| --- | --- | --- | --- | --- |
|
2020-10-21 10:33:43 +08:00
|
|
|
|
| align | 该值将合并到 placement 的配置中,设置参考 [rc-tooltip](https://github.com/react-component/tooltip) | object | - | |
|
2023-03-05 17:51:19 +08:00
|
|
|
|
| arrow | 修改箭头的显示状态以及修改箭头是否指向目标元素中心 | boolean \| { pointAtCenter: boolean } | true | 5.2.0 |
|
2020-06-17 23:18:14 +08:00
|
|
|
|
| autoAdjustOverflow | 气泡被遮挡时自动调整位置 | boolean | true | |
|
2020-05-26 11:41:23 +08:00
|
|
|
|
| color | 背景颜色 | string | - | 4.3.0 |
|
2022-08-26 17:17:13 +08:00
|
|
|
|
| defaultOpen | 默认是否显隐 | boolean | false | 4.23.0 |
|
2023-02-15 10:21:28 +08:00
|
|
|
|
| destroyTooltipOnHide | 关闭后是否销毁 Tooltip | boolean | false | |
|
2022-09-22 10:10:29 +08:00
|
|
|
|
| getPopupContainer | 浮层渲染父节点,默认渲染到 body 上 | (triggerNode: HTMLElement) => HTMLElement | () => document.body | |
|
2020-05-07 13:57:50 +08:00
|
|
|
|
| mouseEnterDelay | 鼠标移入后延时多少才显示 Tooltip,单位:秒 | number | 0.1 | |
|
|
|
|
|
| mouseLeaveDelay | 鼠标移出后延时多少才隐藏 Tooltip,单位:秒 | number | 0.1 | |
|
2020-06-17 23:18:14 +08:00
|
|
|
|
| overlayClassName | 卡片类名 | string | - | |
|
|
|
|
|
| overlayStyle | 卡片样式 | object | - | |
|
2021-06-25 11:04:00 +08:00
|
|
|
|
| overlayInnerStyle | 卡片内容区域的样式对象 | object | - | |
|
2020-06-17 23:18:14 +08:00
|
|
|
|
| placement | 气泡框位置,可选 `top` `left` `right` `bottom` `topLeft` `topRight` `bottomLeft` `bottomRight` `leftTop` `leftBottom` `rightTop` `rightBottom` | string | `top` | |
|
2020-10-21 10:33:43 +08:00
|
|
|
|
| trigger | 触发行为,可选 `hover` \| `focus` \| `click` \| `contextMenu`,可使用数组设置多个触发行为 | string \| string\[] | `hover` | |
|
2023-01-06 12:36:43 +08:00
|
|
|
|
| open | 用于手动控制浮层显隐,小于 4.23.0 使用 `visible`([为什么?](/docs/react/faq#弹层类组件为什么要统一至-open-属性)) | boolean | false | 4.23.0 |
|
2021-05-07 17:38:45 +08:00
|
|
|
|
| zIndex | 设置 Tooltip 的 `z-index` | number | - | |
|
2022-09-22 10:10:29 +08:00
|
|
|
|
| onOpenChange | 显示隐藏的回调 | (open: boolean) => void | - | 4.23.0 |
|
2017-01-22 14:26:46 +08:00
|
|
|
|
|
2023-04-11 10:25:24 +08:00
|
|
|
|
## Design Token
|
|
|
|
|
|
|
|
|
|
<ComponentTokenTable component="Tooltip"></ComponentTokenTable>
|
|
|
|
|
|
2023-07-25 11:38:38 +08:00
|
|
|
|
## FAQ
|
|
|
|
|
|
|
|
|
|
### 为何有时候 HOC 组件无法生效?
|
2017-01-22 14:26:46 +08:00
|
|
|
|
|
2023-07-28 17:39:38 +08:00
|
|
|
|
请确保 `Tooltip` 的子元素能接受 `onMouseEnter`、`onMouseLeave`、`onPointerEnter`、`onPointerLeave`、`onFocus`、`onClick` 事件。
|
2023-07-25 11:38:38 +08:00
|
|
|
|
|
|
|
|
|
### placement 的行为逻辑是什么?
|
|
|
|
|
|
|
|
|
|
当屏幕空间足够时,会按照 `placement` 的设置进行弹层。当空间不足时则会取反向位置进行弹层(例如 `top` 不够时,会改为 `bottom`,`topLeft` 不够时会改为 `bottomLeft`)。单一方向如 `top` `bottom` `left` `right` 当贴边时进行自动位移:
|
|
|
|
|
|
|
|
|
|
<img alt="shift" height="200" src="https://mdn.alipayobjects.com/huamei_7uahnr/afts/img/A*sxaTTJjLtIMAAAAAAAAAAAAADrJ8AQ/original" />
|
|
|
|
|
|
|
|
|
|
当设置为边缘对齐方向如 `topLeft` `bottomRight` 等,则会仅做翻转而不做位移。
|