气泡卡片 Popover 
点击/鼠标移入元素,弹出气泡式的卡片浮层。
何时使用 
- 当目标元素有进一步的描述和相关操作时,可以收纳到卡片中,根据用户的操作行为进行展现。
 - 和 
Tooltip的区别是,用户可以对浮层上的元素进行操作,因此它可以承载更复杂的内容,比如链接或按钮等。 
基本使用 
Show Code
vue
<script setup lang="ts">
function openChange (open: boolean) {
  console.log('open', open)
}
</script>
<template>
  <Popover title="Title" @open-change="openChange">
    <template #content>
      <p>Content</p>
      <p>Content</p>
    </template>
    <Button type="primary">Hover me</Button>
  </Popover>
</template>自定义样式 
Show Code
vue
<template>
  <Popover
    :max-width="180"
    bg-color="#000"
    :title-style="{ fontSize: '16px', fontWeight: 'bold', color: '#1677ff' }"
    :content-style="{ color: '#fff' }"
    :tooltip-style="{ padding: '12px 18px', borderRadius: '12px' }"
  >
    <template #title> Custom Title </template>
    <template #content>
      <p>Custom Content</p>
      <p>Custom Content</p>
    </template>
    <Button type="primary">Hover me</Button>
  </Popover>
</template>不同的触发方式 
Show Code
vue
<template>
  <Space>
    <Popover title="Hover Title">
      <template #content>
        <p>Content</p>
        <p>Content</p>
      </template>
      <Button type="primary">Hover Me</Button>
    </Popover>
    <Popover title="Click Title" trigger="click">
      <template #content>
        <p>Content</p>
        <p>Content</p>
      </template>
      <Button type="primary">Click Me</Button>
    </Popover>
  </Space>
</template>从浮层内关闭 
使用 show 属性控制显示隐藏
Show Code
vue
<script setup lang="ts">
import { ref } from 'vue'
const show = ref(false)
</script>
<template>
  <Popover v-model:show="show" title="Click Title" trigger="click">
    <template #content>
      <a @click="show = false">Close</a>
    </template>
    <Button type="primary">Click Me</Button>
  </Popover>
</template>自定义过渡动画时间 
Show Code
vue
<script setup lang="ts">
import { ref } from 'vue'
const show = ref(false)
</script>
<template>
  <Popover title="Transition Duration 300ms" :transition-duration="300">
    <template #content>
      <p>Content</p>
      <p>Content</p>
    </template>
    <Button type="primary">Transition Duration 300ms</Button>
  </Popover>
</template>延迟显示隐藏 
Show Code
vue
<template>
  <Space>
    <Popover
      :show-delay="300"
      :hide-delay="300"
      title="delay 300ms"
      content="Composed UI"
    >
      <Button type="primary">Delay 300ms Popover</Button>
    </Popover>
    <Popover
      :show-delay="500"
      :hide-delay="500"
      title="delay 500ms"
      content="Composed UI"
    >
      <Button type="primary">Delay 500ms Popover</Button>
    </Popover>
  </Space>
</template>隐藏箭头 
Show Code
vue
<template>
  <Popover :arrow="false" title="Title">
    <template #content>
      <p>Content</p>
      <p>Content</p>
    </template>
    <Button type="primary">Hide Arrow</Button>
  </Popover>
</template>更多使用方式请参考 文字提示 Tooltip
APIs 
Popover 
| 参数 | 说明 | 类型 | 默认值 | 
|---|---|---|---|
| title | 卡片标题 | string | slot | undefined | 
| titleStyle | 卡片标题样式 | CSSProperties | {} | 
| content | 卡片内容 | string | slot | undefined | 
| contentStyle | 卡片内容样式 | CSSProperties | {} | 
| keyboard | 是否支持按键操作 (enter 显示;esc 关闭) | boolean | true | 
| tooltipStyle | 设置弹出提示的样式 | CSSProperties | {} | 
更多属性请参考 Tooltip
Slots 
| 名称 | 说明 | 类型 | 
|---|---|---|
| title | 自定义卡片标题 | v-slot:title | 
| content | 自定义卡片内容 | v-slot:content | 
| default | 自定义内容 | v-solt:default | 
Events 
| 名称 | 说明 | 类型 | 
|---|---|---|
| openChange | 显示隐藏的回调 | (open: boolean) => void |