在 Tooltip 的默认插槽中使用Button或任何其他组件。
<template>
<UTooltip text="Open on GitHub">
<UButton label="Open" color="neutral" variant="subtle" />
</UTooltip>
</template>
App组件包装您的应用程序,该组件使用了TooltipProvider组件(来自 Reka UI)。使用text属性设置 Tooltip 的内容。
<template>
<UTooltip text="Open on GitHub">
<UButton label="Open" color="neutral" variant="subtle" />
</UTooltip>
</template>
使用kbds属性在 Tooltip 中渲染Kbd组件。
<template>
<UTooltip text="Open on GitHub" :kbds="['meta', 'G']">
<UButton label="Open" color="neutral" variant="subtle" />
</UTooltip>
</template>
meta,它在 macOS 上显示为⌘,在其他平台上显示为Ctrl。使用delay-duration属性更改 Tooltip 出现前的延迟。例如,通过将其设置为0,您可以使其立即出现。
<template>
<UTooltip :delay-duration="0" text="Open on GitHub">
<UButton label="Open" color="neutral" variant="subtle" />
</UTooltip>
</template>
App组件中的tooltip.delayDuration选项进行全局配置。使用content属性控制 Tooltip 内容的渲染方式,例如它的align或side。
<template>
<UTooltip
:content="{
align: 'center',
side: 'bottom',
sideOffset: 8
}"
text="Open on GitHub"
>
<UButton label="Open" color="neutral" variant="subtle" />
</UTooltip>
</template>
使用arrow属性在 Tooltip 上显示箭头。
<template>
<UTooltip arrow text="Open on GitHub">
<UButton label="Open" color="neutral" variant="subtle" />
</UTooltip>
</template>
使用disabled属性禁用 Tooltip。
<template>
<UTooltip disabled text="Open on GitHub">
<UButton label="Open" color="neutral" variant="subtle" />
</UTooltip>
</template>
您可以通过使用default-open prop 或v-model:open指令来控制打开状态。
<script setup lang="ts">
const open = ref(false)
defineShortcuts({
o: () => open.value = !open.value
})
</script>
<template>
<UTooltip v-model:open="open" text="Open on GitHub">
<UButton label="Open" color="neutral" variant="subtle" />
</UTooltip>
</template>
defineShortcuts,您可以通过按下O来切换 Tooltip。您可以使用以下方法在悬停在元素上时使 Tooltip 跟随光标reference属性
<script setup lang="ts">
const open = ref(false)
const anchor = ref({ x: 0, y: 0 })
const reference = computed(() => ({
getBoundingClientRect: () =>
({
width: 0,
height: 0,
left: anchor.value.x,
right: anchor.value.x,
top: anchor.value.y,
bottom: anchor.value.y,
...anchor.value
} as DOMRect)
}))
</script>
<template>
<UTooltip
:open="open"
:reference="reference"
:content="{ side: 'top', sideOffset: 16, updatePositionStrategy: 'always' }"
>
<div
class="flex items-center justify-center rounded-md border border-dashed border-accented text-sm aspect-video w-72"
@pointerenter="open = true"
@pointerleave="open = false"
@pointermove="(ev) => {
anchor.x = ev.clientX
anchor.y = ev.clientY
}"
>
Hover me
</div>
<template #content>
{{ anchor.x.toFixed(0) }} - {{ anchor.y.toFixed(0) }}
</template>
</UTooltip>
</template>
| 属性 | 默认值 | 类型 |
|---|---|---|
文本 | string工具提示的文本内容。 | |
键盘按键 | (string | undefined)[] | KbdProps[]在工具提示中显示的键盘按键。
| |
内容 | { 侧面: '底部', 侧面偏移量: 8, 碰撞填充: 8 } | TooltipContentProps & Partial<EmitsToProps<TooltipContentImplEmits>>工具提示的内容。
|
arrow | false | boolean | TooltipArrowProps在工具提示旁边显示箭头。 |
portal | true | string | false | true | HTMLElement在门户中渲染工具提示。 |
reference | Element | VirtualElement用于定位的引用(或锚点)元素。 如果未提供,将使用当前组件作为锚点。
| |
defaultOpen | boolean工具提示在初始渲染时的打开状态。当您不需要控制其打开状态时使用。 | |
open | boolean工具提示的受控打开状态。 | |
delayDuration | 700 | number覆盖给 |
disableHoverableContent | boolean阻止 Tooltip.Content 在悬停时保持打开状态。禁用此功能会影响可访问性。继承自 Tooltip.Provider。 | |
disableClosingTrigger | false | boolean当 |
disabled | false | boolean当 |
ignoreNonKeyboardFocus | false | boolean通过与 |
ui | { content?: ClassNameValue; arrow?: ClassNameValue; text?: ClassNameValue; kbds?: ClassNameValue; kbdsSize?: ClassNameValue; } |
| 插槽 | 类型 |
|---|---|
default | { open: boolean; } |
内容 | { ui: object; } |
| 事件 | 类型 |
|---|---|
update:open | [value: boolean] |
export default defineAppConfig({
ui: {
tooltip: {
slots: {
content: 'flex items-center gap-1 bg-default text-highlighted shadow-sm rounded-sm ring ring-default h-6 px-2.5 py-1 text-xs select-none data-[state=delayed-open]:animate-[scale-in_100ms_ease-out] data-[state=closed]:animate-[scale-out_100ms_ease-in] origin-(--reka-tooltip-content-transform-origin) pointer-events-auto',
arrow: 'fill-default',
text: 'truncate',
kbds: "hidden lg:inline-flex items-center shrink-0 gap-0.5 not-first-of-type:before:content-['·'] not-first-of-type:before:me-0.5",
kbdsSize: 'sm'
}
}
}
})
import { defineConfig } from 'vite'
import vue from '@vitejs/plugin-vue'
import ui from '@nuxt/ui/vite'
export default defineConfig({
plugins: [
vue(),
ui({
ui: {
tooltip: {
slots: {
content: 'flex items-center gap-1 bg-default text-highlighted shadow-sm rounded-sm ring ring-default h-6 px-2.5 py-1 text-xs select-none data-[state=delayed-open]:animate-[scale-in_100ms_ease-out] data-[state=closed]:animate-[scale-out_100ms_ease-in] origin-(--reka-tooltip-content-transform-origin) pointer-events-auto',
arrow: 'fill-default',
text: 'truncate',
kbds: "hidden lg:inline-flex items-center shrink-0 gap-0.5 not-first-of-type:before:content-['·'] not-first-of-type:before:me-0.5",
kbdsSize: 'sm'
}
}
}
})
]
})