<template>
<div id="scroll-wrap">
<div
class="scroll-content"
v-for="item in data"
:key="item.id"
:style="{ top }"
@mouseenter="Stop"
@mouseleave="Up"
>
<slot name="main" :item="item" />
</div>
</div>
</template>
<script>
export default {
name: "roll",
props: {
data: Array,
height: Number,
},
data() {
return {
activeIndex: 0,
time: null,
};
},
computed: {
top() {
return `${-this.activeIndex * this.height}px`;
// 单个轮播项的高度 + (上或下)边距 = 滚动高度
},
},
mounted() {
this.scrollUp();
},
methods: {
scrollUp() {
if(this.time) this.Stop();
this.time = setInterval(() => {
if (this.activeIndex < this.data.length) {
this.activeIndex += 1;
} else {
this.activeIndex = 0;
}
}, 1500);
},
Stop() {
clearInterval(this.time);
},
Up() {
this.scrollUp();
},
},
};
</script>
<style lang="scss" scoped>
#scroll-wrap {
height: 100%;
overflow: hidden;
.scroll-content {
position: relative;
transition: top 0.5s;
}
}
</style>
data:image/s3,"s3://crabby-images/c99f9/c99f98e4dc89cbf868c5375cfd5cba39c9044196" alt="image image"
**粗体** _斜体_ [链接](http://example.com) `代码` - 列表 > 引用
。你还可以使用@
来通知其他用户。