Nuxt UI v3-alpha 已发布!

试试吧
组件

工具提示

显示悬停在元素旁边出现的提示内容。

用法

<template>
  <UTooltip text="Tooltip example" :shortcuts="['⌘', 'O']">
    <UButton color="gray" label="Hover me" />
  </UTooltip>
</template>

Popper

使用 popper 属性自定义 Popper 实例。

箭头

<template>
  <UTooltip text="Tooltip example" :shortcuts="['⌘', 'O']" :popper="{ arrow: true }">
    <UButton color="gray" label="Hover me" />
  </UTooltip>
</template>

放置

<template>
  <UTooltip text="Tooltip example" :shortcuts="['⌘', 'O']" :popper="{ placement: 'right' }">
    <UButton color="gray" label="Hover me" />
  </UTooltip>
</template>

偏移

<template>
  <UTooltip text="Tooltip example" :shortcuts="['⌘', 'O']" :popper="{ offsetDistance: 16 }">
    <UButton color="gray" label="Hover me" />
  </UTooltip>
</template>

插槽

文本

使用 #text 插槽覆盖文本内容。

悬停
<template>
  <UTooltip>
    <template #text>
      <span class="italic">Hello World!</span>
    </template>
  </UTooltip>
</template>

属性

ui
{ wrapper?: string; container?: string; width?: string; background?: string; color?: string; shadow?: string; rounded?: string; ring?: string; base?: string; shortcuts?: string; middot?: string; transition?: DeepPartial<...>; popper?: DeepPartial<...>; default?: DeepPartial<...>; arrow?: DeepPartial<...>; } & { ...;...
{}
文本
字符串
null
popper
PopperOptions
{}
快捷键
字符串数组
[]
打开延迟
数字
config.default.openDelay
关闭延迟
数字
config.default.closeDelay
阻止
布尔值
false

配置

{
  wrapper: 'relative inline-flex',
  container: 'z-20 group',
  width: 'max-w-xs',
  background: 'bg-white dark:bg-gray-900',
  color: 'text-gray-900 dark:text-white',
  shadow: 'shadow',
  rounded: 'rounded',
  ring: 'ring-1 ring-gray-200 dark:ring-gray-800',
  base: '[@media(pointer:coarse)]:hidden h-6 px-2 py-1 text-xs font-normal truncate relative',
  shortcuts: 'hidden md:inline-flex flex-shrink-0 gap-0.5',
  middot: 'mx-1 text-gray-700 dark:text-gray-200',
  transition: {
    enterActiveClass: 'transition ease-out duration-200',
    enterFromClass: 'opacity-0 translate-y-1',
    enterToClass: 'opacity-100 translate-y-0',
    leaveActiveClass: 'transition ease-in duration-150',
    leaveFromClass: 'opacity-100 translate-y-0',
    leaveToClass: 'opacity-0 translate-y-1'
  },
  popper: {
    strategy: 'fixed'
  },
  default: {
    openDelay: 0,
    closeDelay: 0
  },
  arrow: {
    base: '[@media(pointer:coarse)]:hidden invisible before:visible before:block before:rotate-45 before:z-[-1] before:w-2 before:h-2',
    ring: 'before:ring-1 before:ring-gray-200 dark:before:ring-gray-800',
    rounded: 'before:rounded-sm',
    background: 'before:bg-gray-200 dark:before:bg-gray-800',
    shadow: 'before:shadow',
    placement: "group-data-[popper-placement*='right']:-left-1 group-data-[popper-placement*='left']:-right-1 group-data-[popper-placement*='top']:-bottom-1 group-data-[popper-placement*='bottom']:-top-1"
  }
}