71 lines
1.4 KiB
Vue
71 lines
1.4 KiB
Vue
<docs>
|
|
---
|
|
order: 4
|
|
title:
|
|
zh-CN: 自定义指示器
|
|
en-US: custom indicator
|
|
---
|
|
|
|
## zh-CN
|
|
|
|
自定义指示器。
|
|
|
|
## en-US
|
|
|
|
Custom indicator.
|
|
|
|
|
|
</docs>
|
|
|
|
<template>
|
|
<a-button type="primary" @click="handleOpen(true)">Begin Tour</a-button>
|
|
|
|
<a-divider />
|
|
|
|
<a-space>
|
|
<a-button ref="ref1">Upload</a-button>
|
|
<a-button ref="ref2" type="primary">Save</a-button>
|
|
<a-button ref="ref3"><EllipsisOutlined /></a-button>
|
|
</a-space>
|
|
|
|
<a-tour :open="open" :steps="steps" @close="handleOpen(false)">
|
|
<template #indicatorsRender="{ current, total }">
|
|
<span>{{ current + 1 }} / {{ total }}</span>
|
|
</template>
|
|
</a-tour>
|
|
</template>
|
|
|
|
<script lang="ts" setup>
|
|
import { ref } from 'vue';
|
|
import { EllipsisOutlined } from '@ant-design/icons-vue';
|
|
import type { TourProps } from 'ant-design-vue';
|
|
|
|
const open = ref<boolean>(false);
|
|
|
|
const ref1 = ref(null);
|
|
const ref2 = ref(null);
|
|
const ref3 = ref(null);
|
|
|
|
const steps: TourProps['steps'] = [
|
|
{
|
|
title: 'Upload File',
|
|
description: 'Put your files here.',
|
|
target: () => ref1.value && ref1.value.$el,
|
|
},
|
|
{
|
|
title: 'Save',
|
|
description: 'Save your changes.',
|
|
target: () => ref2.value && ref2.value.$el,
|
|
},
|
|
{
|
|
title: 'Other Actions',
|
|
description: 'Click to see other actions.',
|
|
target: () => ref3.value && ref3.value.$el,
|
|
},
|
|
];
|
|
|
|
const handleOpen = (val: boolean): void => {
|
|
open.value = val;
|
|
};
|
|
</script>
|