mirror of
https://gitee.com/bootx/dax-pay-ui.git
synced 2025-09-01 18:17:46 +00:00

* chore: update deps * fix: import.meta.globEager 已过期 * docs: fix doc bugs * fix: eslint * fix: lint:prettier * fix: stylelint * chore: update deps * fix: eslint * refactor: accountdetail setup * fix: 'Nullable' is not defined * feat: remove vite-plugin-vue-setup-extend * chore: remove unplugin-vue-define-options * fix(component): pageWrapper use setup closed #2898 * refactor: PageFooter use setup --------- Co-authored-by: jinmao88 <50581550+jinmao88@users.noreply.github.com>
61 lines
1.8 KiB
Vue
61 lines
1.8 KiB
Vue
<template>
|
|
<PageWrapper title="滚动组件函数示例" content="基于el-scrollbar">
|
|
<div class="my-4">
|
|
<a-button @click="scrollTo(100)" class="mr-2"> 滚动到100px位置 </a-button>
|
|
<a-button @click="scrollTo(800)" class="mr-2"> 滚动到800px位置 </a-button>
|
|
<a-button @click="scrollTo(0)" class="mr-2"> 滚动到顶部 </a-button>
|
|
<a-button @click="scrollBottom()" class="mr-2"> 滚动到底部 </a-button>
|
|
</div>
|
|
<div class="scroll-wrap">
|
|
<ScrollContainer class="mt-4" ref="scrollRef">
|
|
<ul class="p-3">
|
|
<template v-for="index in 100" :key="index">
|
|
<li class="p-2" :style="{ border: '1px solid #eee' }">
|
|
{{ index }}
|
|
</li>
|
|
</template>
|
|
</ul>
|
|
</ScrollContainer>
|
|
</div>
|
|
</PageWrapper>
|
|
</template>
|
|
<script lang="ts">
|
|
import { defineComponent, ref, unref } from 'vue';
|
|
import { ScrollContainer, ScrollActionType } from '/@/components/Container/index';
|
|
import { PageWrapper } from '/@/components/Page';
|
|
import { type Nullable } from '@vben/types';
|
|
|
|
export default defineComponent({
|
|
components: { ScrollContainer, PageWrapper },
|
|
setup() {
|
|
const scrollRef = ref<Nullable<ScrollActionType>>(null);
|
|
const getScroll = () => {
|
|
const scroll = unref(scrollRef);
|
|
if (!scroll) {
|
|
throw new Error('scroll is Null');
|
|
}
|
|
return scroll;
|
|
};
|
|
|
|
function scrollTo(top: number) {
|
|
getScroll().scrollTo(top);
|
|
}
|
|
function scrollBottom() {
|
|
getScroll().scrollBottom();
|
|
}
|
|
return {
|
|
scrollTo,
|
|
scrollRef,
|
|
scrollBottom,
|
|
};
|
|
},
|
|
});
|
|
</script>
|
|
<style lang="less" scoped>
|
|
.scroll-wrap {
|
|
width: 50%;
|
|
height: 300px;
|
|
background-color: @component-background;
|
|
}
|
|
</style>
|