vue实现公告栏⽂字上下滚动效果的⽰例代码本⽂详细的介绍了vue实现公告栏⽂字上下滚动效果的⽰例代码,分享给⼤家,具体⼊如下:
代码实现:
在项⽬结构的components中新建text-scroll.vue⽂件
<template>
<div class="text-container">
<transition class="" name="slide" mode="out-in">
<p class="text" :key="text.id">{{text.val}}</p>
</transition>
</div>
</template>
<script>
export default {
name: 'TextScroll',
props: {
dataList: {
type: Array,
default() {
return [];
},
},
},
data() {
html滚动效果代码
return {
count: 0, // 当前索引
intervalId: null, // 定时器ID
playTime: 2000, // 定时器执⾏间隔
};
},
computed: {
text() {
return {
id: unt,
val: this.unt],
};
},
},
created() {
this.intervalId = setInterval(() => { // 定义定时器
}, this.playTime);
},
methods: {
getText() {
const len = this.dataList.length; // 获取数组长度
if (len === 0) {
return; // 当数组为空时,直接返回
}
if (unt === len - 1) { // 当前为最后⼀个时
} else {
}
},
},
destroyed() {
clearInterval(this.intervalId); // 清除定时器
},
};
</script>
<style scoped>
.text-container{
font-size: 14px;
color: #F56B6B;
margin-right: 20px;
height: 60px;
}
.
text {
text-align: right;
margin: auto 0;
}
.slide-enter-active, .slide-leave-active {
transition: all 1s;
}
.slide-enter{
transform: translateY(40px);
}
.slide-leave-to {
transform: translateY(-40px);
}
</style>
在header-bar组件使⽤
<text-scroll :dataList="noticeList"></text-scroll>
分析
transition标签
这⾥是动态组件
为什么⽤setInterval,⽽不是setTimeout
setInterval是循环执⾏,setTimeout是延迟执⾏。我们这⾥要的是setTimeout循环执⾏。通过嵌套setTimeout可以实现循环,但是每次都会注册⼀个计时器,然后时间上也是需要等当前setTimeout执⾏完再延迟⽐如说两秒执⾏,实际上就不只2s。
什么情况下setTimeout嵌套可以解决 setInterval 解决不了的问题当计时器是⾼耗时的计算或者dom操作时,时间⼤于延迟时间
到此这篇关于vue实现公告栏⽂字上下滚动效果的⽰例代码的⽂章就介绍到这了,更多相关vue 公告栏⽂字上下滚动内容请搜索以前的⽂章或继续浏览下⾯的相关⽂章希望⼤家以后多多⽀持!

版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。