本文详细的介绍了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() { return { count: 0, // 当前索引 intervalId: null, // 定时器ID playTime: 2000, // 定时器执行间隔 }; }, computed: { text() { return { id: this.count, val: this.dataList[this.count], }; }, }, created() { this.intervalId = setInterval(() => { // 定义定时器 this.getText(); }, this.playTime); }, methods: { getText() { const len = this.dataList.length; // 获取数组长度 if (len === 0) { return; // 当数组为空时,直接返回 } if (this.count === len - 1) { // 当前为最后一个时 this.count = 0; // 从第一个开始 } else { this.count++; // 自增 } }, }, 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标签
这里是动态组件
官方文档:https://cn.vuejs.org/v2/guide/transitions.html
为什么用setInterval,而不是setTimeout
setInterval是循环执行,setTimeout是延迟执行。我们这里要的是setTimeout循环执行。通过嵌套setTimeout可以实现循环,但是每次都会注册一个计时器,然后时间上也是需要等当前setTimeout执行完再延迟比如说两秒执行,实际上就不只2s。
什么情况下setTimeout嵌套可以解决 setInterval 解决不了的问题 当计时器是高耗时的计算或者dom操作时,时间大于延迟时间
到此这篇关于vue实现公告栏文字上下滚动效果的示例代码的文章就介绍到这了,更多相关vue 公告栏文字上下滚动 内容请搜索以前的文章或继续浏览下面的相关文章希望大家以后多多支持!
华山资源网 Design By www.eoogi.com
广告合作:本站广告合作请联系QQ:858582 申请时备注:广告合作(否则不回)
免责声明:本站资源来自互联网收集,仅供用于学习和交流,请遵循相关法律法规,本站一切资源不代表本站立场,如有侵权、后门、不妥请联系本站删除!
免责声明:本站资源来自互联网收集,仅供用于学习和交流,请遵循相关法律法规,本站一切资源不代表本站立场,如有侵权、后门、不妥请联系本站删除!
华山资源网 Design By www.eoogi.com
暂无评论...
更新日志
2024年11月20日
2024年11月20日
- 柏菲·甘雅丹《雅鲁藏布》限量开盘母带ORMCD[WAV+CUE]
- 孙露《明天你是否依然爱我》1:1母盘直刻[低速原抓WAV+CUE][1G]
- 群星2024《龙年精选.音乐盛宴》纯银CD[WAV+CUE][1.1G]
- 童丽《君再来VI》妙音首版[WAV+CUE][1G]
- 柏菲·李跃君2024-《寂寞公路》限量开盘母带ORMCD[WAV+CUE]
- 柏菲·古璇2024-《东山飘雨西山晴》限量开盘母带ORMCD[WAV+CUE]
- 群星《2024好听新歌38》AI调整音效【WAV分轨】
- 台湾荷东《周末狂热1》[WAV+CUE][1.1G]
- 群星《Hi.Fi.怀旧金曲.Vol.1》[低速原抓WAV+分轨][996M]
- 汪峰 白金超精选《生来彷徨2CD》[WAV+CUE][1.5G]
- 孙露《寂寞撩人》限量1:1母盘直刻低速原抓[WAV+CUE]
- 20世纪伟大的钢琴家《盖扎·安达》2CD[WAV分轨]
- 龚玥《微风拂面HQCD》[低速原抓WAV+CUE]
- 群星《新说唱2024 第12期 (上)》[320K/MP3][117.13MB]
- 群星《新说唱2024 第12期 (上)》[FLAC/分轨][626.34MB]