vue3实现无限循环滚动的方法;el-table内容无限循环滚动的实现
需求:vue3实现一个div内的内容无限循环滚动
方法一:
<template><div id='container'><div class="item" v-for=item in 5>测试内容{{{ item }}</div></div>
</template><script setup>
//封装一个方法
const fengzhuang = (containerId) => {let intervalId = nullconst container = document.getElementById(containerId)// console.log("container",container.scrollTop);const content = container.scrollHeightlet containerHeight = container.clientHeightlet containerScrollTop = container.scrollToplet currentScrollTop = 0;const startScrolling = () => {stopScrolling()intervalId = setInterval(() => {currentScrollTop += 1.5if(currentScrollTop >= content - containerHeight){currentScrollTop = 0}containerScrollTop = currentScrollTop;container.scrollTop = containerScrollTop;}, 50)}const stopScrolling = () => {clearInterval(intervalId)}const checkOverflow = () => {if (content > containerHeight) {startScrolling()} else {stopScrolling()}}checkOverflow()
}
//进入页面时执行这个方法
onMounted(()=> {fengzhuang('container')
})
</script>
方法二:
<template><div id='container'><div id="content"><div id="scrollWrapper"><div class="item" v-for=item in 5>测试内容{{{ item }}</div></div></div></div>
</template><script setup>
//封装一个方法
let shouldScroll = ref(false)
const fengzhuang2 = (containerId,contentId,scrollWrapperId)=> {const container = document.getElementById(containerId)const content = document.getElementById(contentId)const scrollWrapper = document.getElementById(scrollWrapperId)const startScrolling = (scrollWrapper)=> {const scrollSpeed = 0.01;console.log("scrollWrapper.offsetHeight",scrollWrapper.offsetHeight);const contentHeight = scrollWrapper.offsetHeight;const containerHeight = container.offsetHeight;// 设置初始滚动位置scrollWrapper.style.transform = "translateY(0px)";// 启动动画scrollWrapper.animate([{ transform: "translateY(0px)" },{ transform: `translateY(-${contentHeight-320}px)` },// { transform: `translateY(-${containerHeight}px)` },], {duration: (contentHeight + containerHeight) * scrollSpeed * 1000,easing: "linear",iterations: Infinity,});}if (content.offsetHeight > container.offsetHeight) {shouldScroll.value = true;startScrolling(scrollWrapper);}
}
//进入页面时执行这个方法
onMounted(()=> {fengzhuang2('container','content','scrollWrapper')
})
</script>
方法三:
<template><div class="scroll-container"><div class="scroll-content" :style="contentStyle"><!-- 内容项 --><div v-for="(item, index) in items" :key="index" class="scroll-item" >{{ item }}</div></div></div>
</template><script>
import { ref, onMounted, watchEffect } from "vue";export default {setup() {const items = ref(["Item 1", "Item 2", "Item 3", "Item 4", "Item 5", "Item 6"]); // 你的内容项数组const containerHeight = 200; // 调整滚动容器的高度const scrollSpeed = 0.5; // 调整滚动速度const contentStyle = ref({transform: "translateY(0)",});let currentIndex = 0;const contentHeight = items.value.length * 40; // 假设每个项的高度为40pxconst scrollFrame = () => {currentIndex += scrollSpeed;if (currentIndex >= contentHeight) {currentIndex = 0;}// const itemToMove = items.value.slice(parseInt(currentIndex/40))if(currentIndex % 40 == 0){// const itemToMove = items.value.slice(currentIndex/40)[0]; // 弹出第一个元素// const itemToMove = items.value.shift(); // 弹出第一个元素console.log("itemToMove");items.value.push(itemToMove); // 将弹出的元素放到数组末尾}contentStyle.value.transform = `translateY(-${currentIndex}px)`;};onMounted(() => {// 每帧滚动const scrollInterval = setInterval(scrollFrame, 15); // 16ms对应60帧每秒// 当滚动容器高度改变时,重新计算当前位置以实现无缝滚动watchEffect(() => {// currentIndex = currentIndex % contentHeight;contentStyle.value.transform = `translateY(-${currentIndex}px)`;});// 清除滚动定时器return () => clearInterval(scrollInterval);});return {items,contentStyle,};},
};
</script><style scoped>
.scroll-container {height: 40px; /* 调整滚动容器的高度 */overflow: hidden;border: 1px solid #ccc;
}.scroll-content {display: flex;flex-direction: column;animation: scroll 5s linear infinite; /* 5秒完成一次滚动,可根据需要调整 */
}.scroll-item {height: 40px; /* 每个滚动项的高度 */line-height: 40px;padding: 10px;background-color: #f0f0f0;
}@keyframes scroll {0% {transform: translateY(0);}100% {transform: translateY(-100%);}
}
</style>
补充:el-table实现内容无限循环滚动方法:
let scrollHeight = 0
let currentScrollTop = 0
let maxScrollTop = 0
let timeInter = null
let timeInter2 = null
const tableNode = ref<any>(null)function updateList() {// 数据大于3条才会滑动if (tableData && tableData.value.length > 4) {// 获取滑动区域DOM 最新版本的element-plus节点有变化, 此版本为1.2.0-beta.3tableNode.value = tableRef.value.$refs.bodyWrapper.getElementsByClassName('el-scrollbar__wrap')[0] // 设置每次滑动几行scrollHeight = tableNode.value.querySelectorAll('tr')[0].offsetHeight * 4// 设置每次滑动的PX和滑动区域的高度tableNode.value.style.height = `${scrollHeight}px`// 获取最大滑动空间maxScrollTop = tableNode.value.firstElementChild.offsetHeight - scrollHeight// 开始restTimeInter()}
}function restTimeInter() {// 清除所有定时器clearAllInterval()// 设置定时器timeInter = setInterval(setMultiLine, 1500)
}
function clearAllInterval() {clearInterval(timeInter)clearInterval(timeInter2)
}
function setScrollTop() {tableNode.value.scrollTop++if (tableNode.value.scrollTop >= currentScrollTop) { // 达到下次应该滑动的位置clearInterval(timeInter2)}if (tableNode.value.scrollTop > maxScrollTop) { // 滑到底了tableNode.value.scrollTop = maxScrollTopclearInterval(timeInter2)}
}
function setMultiLine() {// 下次应该滑到哪currentScrollTop = (tableNode.value.scrollTop || 0) + scrollHeight + currentScrollTop % scrollHeightif (tableNode.value.scrollTop >= maxScrollTop) { // 滑完了 重置currentScrollTop = 0tableNode.value.scrollTop = 0restTimeInter()} else {// 清除上一个定时器clearInterval(timeInter2)// 开始滑timeInter2 = setInterval(setScrollTop, 10)}
}
onMounted(()=> {setTimeout(() => {updateList()}, 1000)
})
以上三种方法均能实现无限循环滚动,但是滚动的效果不是无缝衔接的,是滚动到最底部后直接闪现到内容顶部开始重新滚动;要想实现无缝衔接滚动,目前用js是难以实现的,为此花费了好长时间也没能实现,最后在bd中查到了可以实现这一功能的插件,比如vue3-seamless-scroll插件,具体的插件安装和使用可自行百度;
相关文章:
vue3实现无限循环滚动的方法;el-table内容无限循环滚动的实现
需求:vue3实现一个div内的内容无限循环滚动 方法一: <template><div idcontainer><div class"item" v-foritem in 5>测试内容{{{ item }}</div></div> </template><script setup> //封装一个方法…...
Windows 安装 MariaDB 数据库
之前一直使用 MySQL,使用 MySQL8.0 时候,占用内存比较大,储存空间好像也稍微有点大,看到 MariaDB 是用来代替 MySQL 的方案,之前用着也挺得劲,MySQL8.0 以上好像不能去导入低版本的 sql,或者需要…...
RK3568-mpp(Media Process Platform)媒体处理软件平台
第一章 MPP 介绍 1.1 概述 瑞芯微提供的媒体处理软件平台(Media Process Platform,简称 MPP)是适用于瑞芯微芯片系列的通用媒体处理软件平台。 该平台对应用软件屏蔽了芯片相关的复杂底层处理,其目的是为了屏蔽不同芯片的差异,为使用者提供统一的视频媒体处理接口(Medi…...
【ModelSim】使用终端命令行来编译、运行Verilog程序,创建脚本教程
▚ 01 ModelSim命令解说 📢 这些命令是 ModelSim 中常用的命令,用于创建库、编译源代码和启动仿真。 🔔 在使用这些命令之前,你需要在 ModelSim 的命令行界面或脚本中执行 vlib 命令来创建一个库,然后使用 vlog 命令…...
腾讯云网站备案详细流程_审核时间说明
腾讯云网站备案流程先填写基础信息、主体信息和网站信息,然后提交备案后等待腾讯云初审,初审通过后进行短信核验,最后等待各省管局审核,前面腾讯云初审时间1到2天左右,最长时间是等待管局审核时间,网站备案…...
HTTP介绍:一文了解什么是HTTP
前言: 在当今数字时代,互联网已经成为人们生活中不可或缺的一部分。无论是浏览网页、发送电子邮件还是在线购物,我们都离不开超文本传输协议(HTTP)。HTTP作为一种通信协议,扮演着连接客户端和服务器的重要角…...
动态规划之子数组系列
子数组系列 1. 环形⼦数组的最⼤和2. 乘积最大子数组3. 等差数列划分4. 最长湍流子数组5. 单词拆分6. 环绕字符串中唯⼀的子字符串 1. 环形⼦数组的最⼤和 1.题目链接:环形⼦数组的最⼤和 2.题目描述:给定一个长度为 n 的环形整数数组 nums ,…...
LeetCode(力扣)332.重新安排行程Python
LeetCode332.重新安排行程 题目链接代码 题目链接 https://leetcode.cn/problems/reconstruct-itinerary/ 代码 class Solution:def backtracking(self, tickets, used, cur, result, path):if len(path) len(tickets) 1:result.append(path[:])return Truefor i, ticket…...
Pytho 从列表中创建字典 (dict.fromkeys()的问题)
问题起因:想在代码中通过已有的列表创建一个字典,但是又不想写循环,更不想手动填,所以用到了字典对象的fromkeys()方法 。 先以一个简单的例子介绍一下该方法: a ["A", "B", "C", &qu…...
第14节-PhotoShop基础课程-图框工具
文章目录 前言1.矩形画框2.椭圆画框 前言 图框 上面两张图,生成下面一幅图,这个就是图框工具的作用 图框工具ICON 1.矩形画框 2.椭圆画框...
使用 Nacos 在 Spring Boot 项目中实现服务注册与配置管理
🌷🍁 博主猫头虎(🐅🐾)带您 Go to New World✨🍁 🦄 博客首页——🐅🐾猫头虎的博客🎐 🐳 《面试题大全专栏》 🦕 文章图文…...
package.json中workspaces详解与monorepo
参考package.json配置详解,让你一看就会(下) - 掘金...
Spring Boot + Vue的网上商城之商品信息展示
Spring Boot Vue的网上商城之商品信息展示 当实现一个Spring Boot Vue的网上商城的商品信息展示时,可以按照以下步骤进行: 后端实现: 创建一个Spring Boot项目,并添加所需的依赖,包括Spring Web和Spring Data JPA。…...
深度优先搜索遍历与广度优先搜索遍历
目录 一.深度优先搜索遍历 1.深度优先遍历的方法 2.采用邻接矩阵表示图的深度优先搜索遍历 3.非连通图的遍历 二.广度优先搜索遍历 1.广度优先搜索遍历的方法 2.非连通图的广度遍历 3.广度优先搜索遍历的实现 4.按广度优先非递归遍历连通图 一.深度优先搜索遍历 1.深…...
java 中 返回一个空Map
原文链接:Map用法总结 Constructs an empty HashMap with the default initial capacity (16) (mutable) // Constructs an empty HashMap with the default initial capacity (16) and the default load fact // Since:1.2 Map<String, …...
sql 执行插入多条语句中 n个insert 与 一个insert+多个values 性能上有和区别 -- chatGPT
在 SQL 中,你可以使用多种方式来插入多条记录。其中两种常见的方式是: 1. **多个 INSERT 语句**:每个 INSERT 语句都插入一行记录。 sql INSERT INTO table_name (column1, column2, ...) VALUES (value1_1, value1_2, ...); INSERT INTO …...
数学建模国赛C蔬菜类商品的自动定价与补货决策C
数学建模国赛C蔬菜类商品的自动定价与补货决策C 完整思路和代码请私信~~~ 1.拟解决问题 这是一个关于生鲜商超蔬菜商品管理的复杂问题,需要综合考虑销售、补货、定价等多个方面。以下是对这些问题的总结: 问题 1: 蔬菜销售分析 需要分析蔬菜各品类和…...
在程序开发中,接口(interface)的重要性
开了很多人写的程序,都适用了接口,也适用了注入,也没有感到什么不妥。如果只是为了注入而写接口,其实我感觉大可不必,特别是把接口和实体写在一个项目项目中的。 我不知道其他人怎么看接口这一层,接口最大的…...
MyBatis关联关系映射详解
前言 在使用MyBatis进行数据库操作时,关联关系映射是一个非常重要的概念。它允许我们在数据库表之间建立关联,并通过对象之间的关系来进行数据查询和操作。本文将详细介绍MyBatis中的关联关系映射,包括一对一、一对多和多对多关系的处理方法…...
常用电子元器件基础知识
目录 一、电阻 二、电容 三、电感 四、保险丝 五、二极管 一、电阻 概念:顾名思义,就是增加电流通过的阻力的。 就像是在水渠中放入东西,能阻止水的顺利通过也是一个道理。 基于电阻的电气特性,电阻在电路中主要有以下四个…...
git撤销还未push的的提交
怎样撤销掉上图中的提交呢 使用以下代码即可提交 git reset --soft HEAD^...
MySQL--数据库基础
数据库分类 数据库大体可以分为 关系型数据库 和 非关系型数据库 常用数据类型 数值类型: 分为整型和浮点型: 字符串类型 日期类型...
Excel相关笔记
1、找出B列中A列没有的数据并放在C列 公式:IF(ISNA(VLOOKUP(B1,$A 1 : 1: 1:A$4,1,FALSE)),B1,“”)...
RouterOS-配置PPPoEv4v6 Server
1 接口 ether3 出接口 ether4 内网接口 2 出接口 出接口采用PPPoE拨号SLAAC获取前缀,手动配置后缀 2.1 选择出接口interface,配置PPPoE client模式 2.2 配置PPPoE client用户名和密码 2.3 从PPPoE client获取前缀地址池 2.4 给出接口选择前缀并配置…...
PhpStorm软件安装包分享(附安装教程)
目录 一、软件简介 二、软件下载 一、软件简介 PhpStorm是一款由JetBrains开发的专业PHP集成开发环境(IDE),旨在提供全面的PHP开发支持。它是基于IntelliJ IDEA平台构建的,具有强大的功能和工具,可以帮助开发人员提高…...
JavaScript设计模式(三)——单例模式、装饰器模式、适配器模式
个人简介 👀个人主页: 前端杂货铺 🙋♂️学习方向: 主攻前端方向,正逐渐往全干发展 📃个人状态: 研发工程师,现效力于中国工业软件事业 🚀人生格言: 积跬步…...
LeetCode:有序数组的平方
题目 给你一个按 非递减顺序 排序的整数数组 nums,返回 每个数字的平方 组成的新数组,要求也按 非递减顺序 排序。 示例 1: 输入:nums [-4,-1,0,3,10] 输出:[0,1,9,16,100] 解释:平方后,数组变…...
数学分析:势场
首先从散度的物理解释开始。首先,在球内的向量场的散度的积分,等于它在球边界上的流量的积分。所以根据积分中值定理,我们可以这么理解散度,它就是这个体积内的速度场的平均密度。而速度场只和源有关,所以它表示的某个…...
MySQL 中 MyISAM 与 InnoDB 引擎的区别
分析&回答 区别很多,大家说出下面几点,面试就应该 OK 了 1) 事务支持 MyISAM不支持事务,而InnoDB支持。InnoDB的AUTOCOMMIT默认是打开的,即每条SQL语句会默认被封装成一个事务,自动提交,这样会影响速…...
【javascript】禁止浏览器调试前端页面
目录 为啥要禁止?无限 debugger基础禁止调试解决对策 为啥要禁止? 由于前端页面会调用很多接口,有些接口会被别人爬虫分析,破解后获取数据,为了杜绝这种情况,最简单的方法就是禁止人家调试自己的前端代码 …...
什么类型的产品可以做网站出口/产品怎么做推广和宣传
一、员工在公司猝死公司应承担什么责任 1、员工在公司猝死公司应承担赔偿责任。员工在公司上班时猝死应算工伤。 2、法律规定,在工作时间和工作岗位,突发疾病死亡或者在48小时之内经抢救无效死亡的视同工伤,可以要求单位按工伤进行赔偿。 …...
白虎在线观看完整版/图片seo优化是什么意思
ORACLE常见问题一千问[101至200](不怕学不成、就怕心不诚!) ——通过知识共享树立个人品牌。 ORACLE常见问题是我收集完成,在此共享出来,一为自己以后好做个参考,二为需要的朋友提供帮助。同时,感谢提供这些相关问题及…...
wordpress esc html/什么网站百度收录快
项目介绍 一款 Java 语言基于 SpringBoot2.x、Layui、Thymeleaf、MybatisPlus、Shiro、MySQL等框架精心打造的一款模块化、插件化、高性能的前后端分离架构敏捷开发框架,可用于快速搭建后台管理系统,本着简化开发、提升开发效率的初衷,框架自…...
网站底部特效/长沙正规seo优化价格
自定义 ASP.NET UpdatePanel 控件的错误处理.NET Framework 4 其他版本 此主题尚未评级 - 评价此主题 如果在 UpdatePanel 控件中更新部分页时发生错误,则默认行为是显示带有错误消息的浏览器消息框。 本教程将向您演示如何自定义向用户显示错误的方式以及如何自定义…...
网站建设的基本条件/seo整站优化更能准确获得客户
2019独角兽企业重金招聘Python工程师标准>>> RESTful Web 服务简介 REST 在 2000 年由 Roy Fielding 在博士论文中提出,他是 HTTP 规范 1.0 和 1.1 版的首席作者之一。 REST 中最重要的概念是资源(resources),使用全球…...
网站建设技术的发展/百度推广客户端官方下载
栈区 用于存放局部变量 也就是说,任何函数里面,我们定义的变量,不加任何修饰,那么这些变量都是保持在栈区里的 静态全局区 未初始化的静态全局区 静态变量(static修饰的变量)或全局变量(在主函数外,不属…...