72 lines
1.5 KiB
Vue
72 lines
1.5 KiB
Vue
<docs>
|
|
---
|
|
order: 4
|
|
title:
|
|
zh-CN: 悬停点击弹出窗口
|
|
en-US: Hover with click popover
|
|
---
|
|
|
|
## zh-CN
|
|
|
|
以下示例显示如何创建可悬停和单击的弹出窗口。
|
|
|
|
## en-US
|
|
|
|
The following example shows how to create a popover which can be hovered and clicked.
|
|
|
|
</docs>
|
|
<template>
|
|
<a-popover
|
|
style="width: 500px"
|
|
title="Hover title"
|
|
trigger="hover"
|
|
:open="hovered"
|
|
@openChange="handleHoverChange"
|
|
>
|
|
<template #content>
|
|
<div>This is hover content.</div>
|
|
</template>
|
|
<a-popover title="Click title" trigger="click" :open="clicked" @openChange="handleClickChange">
|
|
<template #content>
|
|
<div>
|
|
<div>This is click content.</div>
|
|
<a @click="hide">Close</a>
|
|
</div>
|
|
</template>
|
|
<a-button>Hover and click / 悬停并单击</a-button>
|
|
</a-popover>
|
|
</a-popover>
|
|
</template>
|
|
<script lang="ts">
|
|
import { defineComponent, ref } from 'vue';
|
|
export default defineComponent({
|
|
setup() {
|
|
const clicked = ref<boolean>(false);
|
|
const hovered = ref<boolean>(false);
|
|
|
|
const hide = () => {
|
|
clicked.value = false;
|
|
hovered.value = false;
|
|
};
|
|
|
|
const handleHoverChange = (visible: boolean) => {
|
|
clicked.value = false;
|
|
hovered.value = visible;
|
|
};
|
|
|
|
const handleClickChange = (visible: boolean) => {
|
|
clicked.value = visible;
|
|
hovered.value = false;
|
|
};
|
|
|
|
return {
|
|
clicked,
|
|
hovered,
|
|
hide,
|
|
handleHoverChange,
|
|
handleClickChange,
|
|
};
|
|
},
|
|
});
|
|
</script>
|