tooltip 概览
Angular Material 提示框提供了一种文本标签,当用户的鼠标悬停或长按某个元素时,它就会显示出来。
The Angular Material tooltip provides a text label that is displayed when the user hovers over or longpresses an element.
定位
Positioning
提示框将会显示在本元素的下方,但可以使用输入属性 matTooltipPosition
进行配置。
提示框可以显示在元素的上方、下方、左侧或右侧,默认是下方。如果希望该提示框在 RTL 布局下自动调换左右位置,则应该用 before
和 after
代替 left
和 right
。
The tooltip will be displayed below the element but this can be configured using the
matTooltipPosition
input.
The tooltip can be displayed above, below, left, or right of the element. By default the position
will be below. If the tooltip should switch left/right positions in an RTL layout direction, then
the positions before
and after
should be used instead of left
and right
, respectively.
位置 Position |
说明 Description |
---|---|
above |
总是显示在元素上方 Always display above the element |
below |
总是显示在元素下方 Always display beneath the element |
left |
总是显示在元素左侧 Always display to the left of the element |
right |
总是显示在元素右侧 Always display to the right of the element |
before |
在 LTR 布局下显示在左侧,RTL 布局下显示在右侧 Display to the left in left-to-right layout and to the right in right-to-left layout |
after |
在 LTR 布局下显示在右侧,RTL 布局下显示在左侧 Display to the right in left-to-right layout and to the left in right-to-left layout |
Based on the position in which the tooltip is shown, the .mat-tooltip-panel
element will receive a
CSS class that can be used for style (e.g. to add an arrow). The possible classes are
mat-tooltip-panel-above
, mat-tooltip-panel-below
, mat-tooltip-panel-left
,
mat-tooltip-panel-right
.
显示与隐藏
Showing and hiding
默认情况下,当用户把鼠标移到到触发器元素上时,提示框会立刻显示出来;鼠标离开时会立刻隐藏。
By default, the tooltip will be immediately shown when the user's mouse hovers over the tooltip's trigger element and immediately hides when the user's mouse leaves.
在移动设备上,当用户 "长按" 触发器元素时会显示提示框,延迟 1500ms 后自动隐藏。
On mobile, the tooltip is displayed when the user longpresses the element and hides after a delay of 1500ms.
延迟显示与隐藏
Show and hide delays
要想在显示或隐藏提示框之前添加延迟,可以使用输入属性 matTooltipShowDelay
和 matTooltipHideDelay
来以毫秒为单位指定延迟时间。
To add a delay before showing or hiding the tooltip, you can use the inputs matTooltipShowDelay
and matTooltipHideDelay
to provide a delay time in milliseconds.
下面的例子中的提示框会在鼠标移到按钮上之后等待一秒钟再显示,当鼠标移开时等待两秒钟再隐藏。
The following example has a tooltip that waits one second to display after the user hovers over the button, and waits two seconds to hide after the user moves the mouse away.
修改默认的延迟行为
Changing the default delay behavior
你可以使用依赖注入令牌 MAT_TOOLTIP_DEFAULT_OPTIONS
提供一个选项,来配置应用中提示框的默认显示/隐藏延迟。
You can configure your app's tooltip default show/hide delays by configuring and providing
your options using the MAT_TOOLTIP_DEFAULT_OPTIONS
injection token.
手动调用 show() 和 hide()
Manually calling show() and hide()
要想手动显示或隐藏提示框,你可以调用该指令的 show
和 hide
方法,它们可以接受一个以毫秒为单位的数字作为延迟时间。
To manually cause the tooltip to show or hide, you can call the show
and hide
directive methods,
which both accept a number in milliseconds to delay before applying the display change.
禁止显示提示框
Disabling the tooltip from showing
要完全禁用提示框,请设置 matTooltipDisabled
。禁用之后,则永远不会显示出提示框。
To completely disable a tooltip, set matTooltipDisabled
. While disabled, a tooltip will never be
shown.
无障碍性
Accessibility
带有 matTooltip
的元素会添加一个 aria-describedby
标签,它指向一个包含提示信息的不可见元素。
当最终用户把焦点移到用于触发该提示框的元素上时,屏幕阅读器就会读出该提示信息的内容。
aria-describedby
所指向的那个元素并不是提示框本身,而是该提示框内容的一个不可见副本,但它会始终存在于 DOM 中。
Elements with the matTooltip
will add an aria-describedby
label that provides a reference
to a visually hidden element containing the tooltip's message. This provides screenreaders the
information needed to read out the tooltip's contents when the end-user focuses on the element
triggering the tooltip. The element referenced via aria-describedby
is not the tooltip itself,
but instead an invisible copy of the tooltip content that is always present in the DOM.
如果提示框只会通过点击、按键等方式手动显示,还要注意为屏幕阅读器用户提供类似的操作。
可能的方式之一是使用 cdk/a11y
包中的 LiveAnnouncer
来宣读提示信息的内容。
If a tooltip will only be shown manually via click, keypress, etc., then extra care should be taken
such that the action behaves similarly for screen-reader users. One possible approach would be
to use the LiveAnnouncer
from the cdk/a11y
package to announce the tooltip content on such
an interaction.