Tooltip
Всплывающие подсказки отображают информативный текст когда пользователь наводит курсор на элемент, фокусируется на нем или нажимает на него.
При активации, Tooltips отображают текстовую метку, идентифицирующая элемент, например, описание его функции.
<Tooltip title="Delete">
<IconButton>
<DeleteIcon />
</IconButton>
</Tooltip>
Positioned tooltips
The Tooltip
has 12 placements choice. They don't have directional arrows; instead, they rely on motion emanating from the source to convey direction.
Настраиваемые подсказки
Ниже находятся примеры кастомизации компонента. You can learn more about this in the overrides documentation page.
Arrow tooltips
You can use the arrow
prop to give your tooltip an arrow indicating which element it refers to.
<Tooltip title="Add" arrow>
<Button>Arrow</Button>
</Tooltip>
Custom child element
The tooltip needs to apply DOM event listeners to its child element. The tooltip needs to apply DOM event listeners to its child element.
const MyComponent = React.forwardRef(function MyComponent(props, ref) {
// Spread the props to the underlying DOM element.
return <div {...props} ref={ref}>Bin</div>
});
// ...
<Tooltip title="Delete">
<MyComponent>
</Tooltip>
You can find a similar concept in the wrapping components guide.
Триггеры
You can define the types of events that cause a tooltip to show.
Controlled tooltips
Вы можете использовать open
, onOpen
and onClose
свойства, чтобы контролировать поведение всплывающей подсказки.
<Tooltip open={open} onClose={handleClose} onOpen={handleOpen} title="Add">
<Button>Controlled</Button>
</Tooltip>
<Tooltip title={longText}>
<Button sx={{ m: 1 }}>Default Width [300px]</Button>
</Tooltip>
<CustomWidthTooltip title={longText}>
<Button sx={{ m: 1 }}>Custom Width [500px]</Button>
</CustomWidthTooltip>
<NoMaxWidthTooltip title={longText}>
<Button sx={{ m: 1 }}>No wrapping</Button>
</NoMaxWidthTooltip>
Интерактивность
Подсказки интерактивны по умолчанию (чтобы пройти тест WCAG 2.1 success criterion 1.4.13). Перемещение указателя над подсказкой до истечения срока leaveDelay
не приведет к её закрытию. Вы можете отключить это поведение (и таким образом не пройти тест, необходимый для достижения уровня АА), передав disableInteractive
.
<Tooltip title="Add" disableInteractive>
<Button>Not interactive</Button>
</Tooltip>
Disabled elements
By default disabled elements like <button>
do not trigger user interactions so a Tooltip
will not activate on normal events like hover. To accommodate disabled elements, add a simple wrapper element, such as a span
.
⚠️ In order to work with Safari, you need at least one display block or flex item below the tooltip wrapper.
<Tooltip title="You don't have permission to do this">
<span>
<Button disabled>A Disabled Button</Button>
</span>
</Tooltip>
If you're not wrapping a Material-UI component that inherits from
ButtonBase
, for instance, a native<button>
element, you should also add the CSS property pointer-events: none; to your element when disabled:
<Tooltip title="You don't have permission to do this">
<span>
<button disabled={disabled} style={disabled ? <Tooltip title="You don't have permission to do this">
<span>
<button disabled={disabled} style={disabled ?
Переходы
Используйте другой transition.
<Tooltip title="Add">
<Button>Grow</Button>
</Tooltip>
<Tooltip
TransitionComponent={Fade}
TransitionProps={{ timeout: 600 }}
title="Add"
>
<Button>Fade</Button>
</Tooltip>
<Tooltip TransitionComponent={Zoom} title="Add">
<Button>Zoom</Button>
</Tooltip>
Следовать за курсором
Вы можете разрешить подсказке следовать за курсором установкой followCursor={true}
.
<Tooltip title="You don't have permission to do this" followCursor>
<Box sx={{ bgcolor: 'text.disabled', color: 'background.paper', p: 2 }}>
Disabled Action
</Box>
</Tooltip>
Virtual element
Если вам нужно указать собственное положение подсказки, вы можете воспользоваться параметром anchorEl
. Значение anchorEl
может быть ссылкой на имитированный DOM-элемент. You need to create an object shaped like the VirtualElement
.
Отображение и скрытие
Всплывающая подсказка обычно отображается сразу же, как пользователь наводит курсор на элемент, и скрывается, как только курсор уходит с элемента. Задержку в отображении или скрытии всплывающей подсказки можно добавить через свойства enterDelay
и leaveDelay
, как показано выше в демонстрационной версии «Контролируемые подсказки».
On mobile, the tooltip is displayed when the user longpresses the element and hides after a delay of 1500ms. You can disable this feature with the disableTouchListener
property.
<Tooltip title="Add" enterDelay={500} leaveDelay={200}>
<Button>[500ms, 200ms]</Button>
</Tooltip>
Доступность
(WAI-ARIA: https://www.w3.org/TR/wai-aria-practices/#tooltip)
По умолчанию подсказка лишь маркирует дочерний элемент. Это существенно отличает её от title
, который может либо маркировать либо описать свой дочерний элемент в зависимости от того, есть ли у него уже метка. Например, здесь:
<button title="some more information">A button</button>
параметр title
действует как доступное описание. Если вы хотите, чтобы сама подсказка служила доступным описанием, вы можете передать describeChild
. Обратите внимание, вам не следует использовать describeChild
если подсказка предоставляет только визуальную метку. В противном случае дочерний элемент не будет иметь доступного имени, и подсказка нарушит критерий успеха 2.5.3 в WCAG 2.1.
<Tooltip title="Delete">
<IconButton>
<DeleteIcon />
</IconButton>
</Tooltip>
<Tooltip describeChild title="Does not add if it already exists.">
<Button>Add</Button>
</Tooltip>