Vue自定义行数 文字向上滚动轮播效果
效果图 列表无限向上轮播<template><div class="marquee"><div class="marquee_box" ref="marquee_box"><ul class="marquee_list" :class="{marquee_top:animate}"><li v...
·
效果图 列表无限向上轮播
<template>
<div class="marquee">
<div class="marquee_box" ref="marquee_box">
<ul class="marquee_list" :class="{marquee_top:animate}">
<li v-for="(item,index) in list" :key="index">{{item}}</li>
</ul>
</div>
</div>
</template>
<script>
export default {
data () {
return {
animate: false,
showNum: 4, // 可见列表条数
list: [
'1111111111111111111',
'22222222222222222222',
'333333333333333333333',
'4444444444444444444',
'5555555555555555555',
'666666666666666666',
'777777777777777',
'888888888888888888'
]
}
},
created () {
// 页面显示
setInterval(this.showMarquee, 2000)
},
mounted () {
// 可见数据高度
this.$refs.marquee_box.style.height = this.showNum * 30 + 'px'
},
methods: {
// 处理数组方法
showMarquee () {
this.animate = true
this.list.push(this.list[0])
setTimeout(() => {
this.list.shift()
this.animate = false
}, 1000)
}
}
}
</script>
<style scoped>
.marquee {
width: 100%;
/* height: 200px; */
align-items: center;
color: #3a3a3a;
background-color: white;
display: flex;
box-sizing: border-box;
overflow: hidden;
}
.marquee_title {
padding: 0 20px;
height: 21px;
font-size: 14px;
border-right: 1px solid #d8d8d8;
align-items: center;
}
.marquee_box {
display: block;
position: relative;
width: 65%;
overflow: hidden;
margin: 0 auto;
}
.marquee_list {
display: block;
position: absolute;
top: 0px;
left: 0;
}
.marquee_top {
transition: all 1s;
margin-top: -30px;
}
.marquee_list li {
height: 30px;
line-height: 30px;
font-size: 14px;
padding-left: 20px;
}
.marquee_list li span {
padding: 0 2px;
}
</style>
我这么棒,快夸我!!
更多推荐
已为社区贡献17条内容
所有评论(0)