1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
| <template>
| <PageWrapper title="动画组件示例">
| <div class="flex">
| <Select
| :options="options"
| v-model:value="value"
| placeholder="选择动画"
| :style="{ width: '150px' }"
| />
| <a-button type="primary" class="ml-4" @click="start"> start </a-button>
| </div>
| <component :is="`${value}Transition`">
| <div class="box" v-show="show"></div>
| </component>
| </PageWrapper>
| </template>
| <script lang="ts">
| import { defineComponent, ref } from 'vue';
| import { Select } from 'ant-design-vue';
| import { PageWrapper } from '/@/components/Page';
| import {
| FadeTransition,
| ScaleTransition,
| SlideYTransition,
| ScrollYTransition,
| SlideYReverseTransition,
| ScrollYReverseTransition,
| SlideXTransition,
| ScrollXTransition,
| SlideXReverseTransition,
| ScrollXReverseTransition,
| ScaleRotateTransition,
| ExpandXTransition,
| ExpandTransition,
| } from '/@/components/Transition';
|
| const transitionList = [
| 'Fade',
| 'Scale',
| 'SlideY',
| 'ScrollY',
| 'SlideYReverse',
| 'ScrollYReverse',
| 'SlideX',
| 'ScrollX',
| 'SlideXReverse',
| 'ScrollXReverse',
| 'ScaleRotate',
| 'ExpandX',
| 'Expand',
| ];
| const options = transitionList.map((item) => ({
| label: item,
| value: item,
| key: item,
| }));
|
| export default defineComponent({
| components: {
| Select,
| PageWrapper,
| FadeTransition,
| ScaleTransition,
| SlideYTransition,
| ScrollYTransition,
| SlideYReverseTransition,
| ScrollYReverseTransition,
| SlideXTransition,
| ScrollXTransition,
| SlideXReverseTransition,
| ScrollXReverseTransition,
| ScaleRotateTransition,
| ExpandXTransition,
| ExpandTransition,
| },
| setup() {
| const value = ref('Fade');
| const show = ref(true);
| function start() {
| show.value = false;
| setTimeout(() => {
| show.value = true;
| }, 300);
| }
| return { options, value, start, show };
| },
| });
| </script>
| <style lang="less" scoped>
| .box {
| width: 150px;
| height: 150px;
| margin-top: 20px;
| background-color: rgb(126 170 236);
| }
| </style>
|
|