vue2实现列表数据字幕式循环滚动

2024-04-25 21:12

本文主要是介绍vue2实现列表数据字幕式循环滚动,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

一、功能点:

        实现列表“字幕式”滚动效果;

        字幕循环滚动,滚完数据之后会继续从头开始滚动

        实现鼠标移入,字幕停止滚动;鼠标移出,字幕继续滚动;

        实现滚轮在指定区域内滚动,能够控制控制字幕上下滚动

二、代码:

<template><div class="subtitle-container"ref="container"@mouseenter="stopScrolling"@mouseleave="startScrollingOnLeave"@wheel="handleScroll"><ul class="subtitle-list":style="{ transform: `translateY(-${currentScrollTop}px)` }"><li v-for="(subtitle, index) in subtitles":key="index"class="subtitle">{{ subtitle }}</li></ul></div>
</template><script>
export default {data () {return {subtitles: ['在岁月的流逝中,花开花落,却留下了永恒的思念。', '晨曦之光,穿透黑夜的深邃,唤醒沉睡的希望。', '微风轻拂,草木低语,岁月静好,心安如初。', '星空如梦,岁月如歌,心中的孤舟在悠远的彼岸徘徊。', '晨曦之光,穿透黑夜的深邃,唤醒沉睡的希望。', '微风轻拂,草木低语,岁月静好,心安如初。', '情深意浓,宛如一汪清泉,润泽心灵的枯渴。', '山水之间,一念之差,心的旅程,或是波澜壮阔,或是静谧悠长。', '浮生若梦,红尘漫漫,唯有心中的那一抹云彩,永不散去。', '星光璀璨,照亮前行的路途,让希望之花绽放在黑暗中。', '海浪拍岸,千年的沧桑,铭刻着岁月的印记,留下无尽的思绪。', '暮色渐浓,烛光摇曳,思念的火焰在心中燃烧,驱散寂寞的阴霾。'], // 假设这里是你的字幕数据scrollSpeed: 50, // 滚动速度,单位为毫秒scrollInterval: null, // 滚动间隔的引用containerHeight: 0, // 容器高度subtitleHeight: 0, // 单个字幕的高度currentScrollTop: 0, // 当前滚动的位置isHovering: false // 标记鼠标是否悬停在容器上};},mounted () {this.containerHeight = this.$refs.container.offsetHeight;this.subtitleHeight = this.$refs.container.querySelector('.subtitle').offsetHeight;this.startScrolling();},methods: {startScrolling () {if (!this.isHovering) {this.scrollInterval = setInterval(() => {this.currentScrollTop += 1;if (this.currentScrollTop >= this.subtitleHeight) {this.currentScrollTop = 0;this.subtitles.push(this.subtitles.shift());}}, this.scrollSpeed);}},stopScrolling () {clearInterval(this.scrollInterval);this.isHovering = true;},startScrollingOnLeave () {if (this.isHovering) {this.isHovering = false;this.startScrolling();}},handleScroll (event) {this.currentScrollTop += event.deltaY;if (this.currentScrollTop < 0) {this.currentScrollTop = 0;} else if (this.currentScrollTop > (this.subtitles.length * this.subtitleHeight - this.containerHeight)) {this.currentScrollTop = this.subtitles.length * this.subtitleHeight - this.containerHeight;}}},beforeDestroy () {clearInterval(this.scrollInterval); // 在组件销毁前清除滚动间隔}
};
</script><style>
.subtitle-container {text-align: center;margin: 0 auto;margin-top: 30px;overflow: hidden;
}.subtitle-list {padding: 0;margin: 0;list-style-type: none;
}.subtitle {line-height: 30px; /* 调整为适当的行高 */
}
</style>

这篇关于vue2实现列表数据字幕式循环滚动的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/935808

相关文章

HTML5 getUserMedia API网页录音实现指南示例小结

《HTML5getUserMediaAPI网页录音实现指南示例小结》本教程将指导你如何利用这一API,结合WebAudioAPI,实现网页录音功能,从获取音频流到处理和保存录音,整个过程将逐步... 目录1. html5 getUserMedia API简介1.1 API概念与历史1.2 功能与优势1.3

Java实现删除文件中的指定内容

《Java实现删除文件中的指定内容》在日常开发中,经常需要对文本文件进行批量处理,其中,删除文件中指定内容是最常见的需求之一,下面我们就来看看如何使用java实现删除文件中的指定内容吧... 目录1. 项目背景详细介绍2. 项目需求详细介绍2.1 功能需求2.2 非功能需求3. 相关技术详细介绍3.1 Ja

使用Python和OpenCV库实现实时颜色识别系统

《使用Python和OpenCV库实现实时颜色识别系统》:本文主要介绍使用Python和OpenCV库实现的实时颜色识别系统,这个系统能够通过摄像头捕捉视频流,并在视频中指定区域内识别主要颜色(红... 目录一、引言二、系统概述三、代码解析1. 导入库2. 颜色识别函数3. 主程序循环四、HSV色彩空间详解

PostgreSQL中MVCC 机制的实现

《PostgreSQL中MVCC机制的实现》本文主要介绍了PostgreSQL中MVCC机制的实现,通过多版本数据存储、快照隔离和事务ID管理实现高并发读写,具有一定的参考价值,感兴趣的可以了解一下... 目录一 MVCC 基本原理python1.1 MVCC 核心概念1.2 与传统锁机制对比二 Postg

SpringBoot整合Flowable实现工作流的详细流程

《SpringBoot整合Flowable实现工作流的详细流程》Flowable是一个使用Java编写的轻量级业务流程引擎,Flowable流程引擎可用于部署BPMN2.0流程定义,创建这些流程定义的... 目录1、流程引擎介绍2、创建项目3、画流程图4、开发接口4.1 Java 类梳理4.2 查看流程图4

SQL Server修改数据库名及物理数据文件名操作步骤

《SQLServer修改数据库名及物理数据文件名操作步骤》在SQLServer中重命名数据库是一个常见的操作,但需要确保用户具有足够的权限来执行此操作,:本文主要介绍SQLServer修改数据... 目录一、背景介绍二、操作步骤2.1 设置为单用户模式(断开连接)2.2 修改数据库名称2.3 查找逻辑文件名

C++中零拷贝的多种实现方式

《C++中零拷贝的多种实现方式》本文主要介绍了C++中零拷贝的实现示例,旨在在减少数据在内存中的不必要复制,从而提高程序性能、降低内存使用并减少CPU消耗,零拷贝技术通过多种方式实现,下面就来了解一下... 目录一、C++中零拷贝技术的核心概念二、std::string_view 简介三、std::stri

C++高效内存池实现减少动态分配开销的解决方案

《C++高效内存池实现减少动态分配开销的解决方案》C++动态内存分配存在系统调用开销、碎片化和锁竞争等性能问题,内存池通过预分配、分块管理和缓存复用解决这些问题,下面就来了解一下... 目录一、C++内存分配的性能挑战二、内存池技术的核心原理三、主流内存池实现:TCMalloc与Jemalloc1. TCM

OpenCV实现实时颜色检测的示例

《OpenCV实现实时颜色检测的示例》本文主要介绍了OpenCV实现实时颜色检测的示例,通过HSV色彩空间转换和色调范围判断实现红黄绿蓝颜色检测,包含视频捕捉、区域标记、颜色分析等功能,具有一定的参考... 目录一、引言二、系统概述三、代码解析1. 导入库2. 颜色识别函数3. 主程序循环四、HSV色彩空间

全面解析HTML5中Checkbox标签

《全面解析HTML5中Checkbox标签》Checkbox是HTML5中非常重要的表单元素之一,通过合理使用其属性和样式自定义方法,可以为用户提供丰富多样的交互体验,这篇文章给大家介绍HTML5中C... 在html5中,Checkbox(复选框)是一种常用的表单元素,允许用户在一组选项中选择多个项目。本