Reference version

工具提示

Jetpack Compose 工具提示组件,用于在长按时显示上下文信息。

Android
Bundled version:
~55.0.0-beta.0

For the complete documentation index, see llms.txt. Use this Use this file to discover all available pages.

Expo UI Tooltip 与官方 Jetpack Compose Tooltip API 保持一致。TooltipBox 会包裹锚点内容并显示工具提示。工具提示内容通过 TooltipBox.PlainTooltipTooltipBox.RichTooltip 这两个复合组件提供,它们分别对应 PlainTooltipRichTooltip。工具提示可以通过长按触发,也可以通过 ref 以编程方式显示。

安装

Terminal
npx expo install @expo/ui

If you are installing this in an existing React Native app, make sure to install expo in your project.

用法

纯文本工具提示

长按锚点内容以显示工具提示。

PlainTooltipExample.tsx
import { Host, TooltipBox, Button, Text } from '@expo/ui/jetpack-compose'; export default function PlainTooltipExample() { return ( <Host matchContents> <TooltipBox> <TooltipBox.PlainTooltip> <Text>添加到收藏夹</Text> </TooltipBox.PlainTooltip> <Button onClick={() => {}}> <Text>收藏</Text> </Button> </TooltipBox> </Host> ); }

带标题和正文的富文本工具提示

使用 TooltipBox.RichTooltip 搭配 TitleText 复合组件模式,以提供更详细的上下文信息。

RichTooltipExample.tsx
import { Host, TooltipBox, Button, Text } from '@expo/ui/jetpack-compose'; export default function RichTooltipExample() { return ( <Host matchContents> <TooltipBox> <TooltipBox.RichTooltip> <TooltipBox.RichTooltip.Title> <Text>相机</Text> </TooltipBox.RichTooltip.Title> <TooltipBox.RichTooltip.Text> <Text>使用设备相机拍摄照片和录制视频。</Text> </TooltipBox.RichTooltip.Text> </TooltipBox.RichTooltip> <Button onClick={() => {}}> <Text>打开相机</Text> </Button> </TooltipBox> </Host> ); }

带操作的富文本工具提示

使用 TooltipBox.RichTooltip.Action 添加一个可交互操作。使用 isPersistent 让工具提示保持可见,以便用户点击它。存在操作插槽时,hasAction 会自动推导生成。

RichTooltipActionExample.tsx
import { Host, TooltipBox, Button, TextButton, Text } from '@expo/ui/jetpack-compose'; export default function RichTooltipActionExample() { return ( <Host matchContents> <TooltipBox isPersistent> <TooltipBox.RichTooltip> <TooltipBox.RichTooltip.Title> <Text>需要权限</Text> </TooltipBox.RichTooltip.Title> <TooltipBox.RichTooltip.Text> <Text>此功能需要访问相机和麦克风。</Text> </TooltipBox.RichTooltip.Text> <TooltipBox.RichTooltip.Action> <TextButton onClick={() => {}}> <Text>了解更多</Text> </TextButton> </TooltipBox.RichTooltip.Action> </TooltipBox.RichTooltip> <Button onClick={() => {}}> <Text>录制视频</Text> </Button> </TooltipBox> </Host> ); }

编程方式显示和关闭

使用 ref 可以以命令式方式调用 show()dismiss() 来显示或关闭工具提示,而无需长按。

ProgrammaticTooltipExample.tsx
import { useRef } from 'react'; import { Host, TooltipBox, type TooltipBoxRef, Button, Text, Row } from '@expo/ui/jetpack-compose'; export default function ProgrammaticTooltipExample() { const tooltipRef = useRef<TooltipBoxRef>(null); return ( <Host matchContents> <TooltipBox ref={tooltipRef} isPersistent> <TooltipBox.PlainTooltip> <Text>通过编程方式显示!</Text> </TooltipBox.PlainTooltip> <Button onClick={() => {}}> <Text>锚点</Text> </Button> </TooltipBox> <Row horizontalArrangement={{ spacedBy: 8 }}> <Button onClick={() => tooltipRef.current?.show()}> <Text>显示</Text> </Button> <Button onClick={() => tooltipRef.current?.dismiss()}> <Text>关闭</Text> </Button> </Row> </Host> ); }

API

import { TooltipBox } from '@expo/ui/jetpack-compose';

Component

TooltipBox

Android

Type: React.Element<TooltipBoxProps>

A container that wraps anchor content and shows a tooltip on long-press. Provide the tooltip content via TooltipBox.PlainTooltip or TooltipBox.RichTooltip. All other children are the anchor/trigger.

Use ref to imperatively show() or dismiss() the tooltip.

TooltipBoxProps

children

Android
Type: React.ReactNode

Children containing a TooltipBox.PlainTooltip or TooltipBox.RichTooltip slot and the anchor/trigger content. The anchor content triggers the tooltip on long-press.

enableUserInput

Android
Optional • Type: boolean • Default: true

Whether user input (long-press, hover) triggers the tooltip.

focusable

Android
Optional • Type: boolean • Default: false

Whether the tooltip popup is focusable.

hasAction

Android
Optional • Type: boolean

Whether the tooltip contains an action. Affects accessibility and dismiss behavior. When not specified, this is automatically derived from the presence of a RichTooltip.Action slot.

isPersistent

Android
Optional • Type: boolean • Default: false

Whether the tooltip persists instead of auto-dismissing after a short timeout.

modifiers

Android
Optional • Type: ModifierConfig[]

Modifiers for the component.

ref

Android
Optional • Type: Ref<TooltipBoxRef>

Ref to imperatively show/dismiss the tooltip.

Types

TooltipBoxRef

Android
PropertyTypeDescription
dismiss() => Promise<void>

Programmatically dismisses the tooltip.

show() => Promise<void>

Programmatically shows the tooltip.