# vue3
# yarn
yarn add @meruem117/vue-seamless-scroll@latest --dev
# npm
npm i @meruem117/vue-seamless-scroll@latest --save-dev
# vue2
# yarn
yarn add @meruem117/vue-seamless-scroll@latest-v2 --dev
# npm
npm i @meruem117/vue-seamless-scroll@latest-v2 --save-dev
main.ts
import { createApp } from 'vue'
import App from './App.vue'
import { VueSeamlessScroll } from '@meruem117/vue-seamless-scroll'
const app = createApp(App)
app.use(VueSeamlessScroll)
app.mount('#app')
env.d.ts
declare module '@meruem117/vue-seamless-scroll'
App.vue
<template>
<div class="box">
<vue-seamless-scroll class="list" :data="data" direction="top" :steep="0.5" roller :distance="20">
<div class="list-item" v-for="item, index in data" :key="index">{{ item.text }}</div>
</vue-seamless-scroll>
</div>
</template>
<script setup lang="ts">
import { ref } from 'vue'
let data = ref([
{ text: 'test' },
{ text: 'test' },
{ text: 'test' },
{ text: 'test' },
{ text: 'test' },
{ text: 'test' },
{ text: 'test' },
{ text: 'test' },
{ text: 'test' },
{ text: 'test' },
{ text: 'test' },
{ text: 'test' },
{ text: 'test' },
{ text: 'test' },
{ text: 'test' },
{ text: 'test' },
{ text: 'test' },
])
</script>
<style scoped>
.box {
width: 100%;
padding-top: 50px;
display: flex;
justify-content: center;
}
.list {
height: 300px;
overflow: hidden;
}
.list-item {
width: 500px;
height: 100px;
margin-bottom: 20px;
color: #000;
font-size: 14px;
background-color: aliceblue;
}
</style>
属性 | 说明 | 类型 | 默认值 |
---|---|---|---|
direction | 滚动的方向 | 'top' | 'bottom' | 'left' | 'right' | 'top' |
steep | 滚动的速率 | number | 0.5 |
roller | 是否可以使用滚轮滚动 | boolean | true |
distance | 滚轮滚动的速率 | number | 20 |
data | 接收异步数据,同步任务可不传 | array | - |
- 如没有显示请为嵌入的标签设置字体大小
- 当
direction
为top
或bottom
时,要为组件设置高度;当direction
为left
或right
时,要为组件设置宽度 - reference: @david-j/vue-j-scroll