工具提示 Tooltip

tooltip 概览

Angular Material 提示框提供了一种文本标签,当用户的鼠标悬停或长按某个元素时,它就会显示出来。

The Angular Material tooltip provides a text label that is displayed when the user hovers over or longpresses an element.

Basic tooltip

提示框将会显示在本元素的下方,但可以使用输入属性 matTooltipPosition 进行配置。 提示框可以显示在元素的上方、下方、左侧或右侧,默认是下方。如果希望该提示框在 RTL 布局下自动调换左右位置,则应该用 beforeafter 代替 leftright

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.

Tooltip with a custom position

默认情况下,当用户把鼠标移到到触发器元素上时,提示框会立刻显示出来;鼠标离开时会立刻隐藏。

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.

要想在显示或隐藏提示框之前添加延迟,可以使用输入属性 matTooltipShowDelaymatTooltipHideDelay 来以毫秒为单位指定延迟时间。

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.

Tooltip with a show and hide delay
milliseconds
milliseconds

你可以使用依赖注入令牌 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.

Tooltip with a show and hide delay

要想手动显示或隐藏提示框,你可以调用该指令的 showhide 方法,它们可以接受一个以毫秒为单位的数字作为延迟时间。

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.

Tooltip that can be manually shown/hidden.
Click the following buttons to...

要完全禁用提示框,请设置 matTooltipDisabled。禁用之后,则永远不会显示出提示框。

To completely disable a tooltip, set matTooltipDisabled. While disabled, a tooltip will never be shown.

带有 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.