vue表格自动滚动(vue3 如何实现 表格内容无缝滚动,我又写了一堆冗余代码)
背景
近期在开发可视化大屏项目 ,除去各种echarts图表和地图展示之外还有多个表格 。现在来了一个需求 ,需要将大屏中的所有表格设置为内容无缝滚动 。
本着程序员的七宗罪原则第一时间推脱了一下 ,但没推脱成功 。 简单的在网上查了下适合我们项目的有两种方案 ,第一种是使用一款插件 vue3-seamless-scroll 第二种方案是自己写JS代码通过计时器去控制表格滚动条自动滚动方案一
从实际开发上考虑使用如果有类似功能开箱即用没什么问题的插件当然是最好不过的 ,能提高不少工作效率达到准时下班的目的
vue3-seamless-scroll(点击进入官方文档)
根据插件描述说是目前组件支持上下左右无缝滚动 ,单步滚动 ,并且支持复杂图标的无缝滚动 ,支持平台与Vue3.0支持平台一致 。
安装
npm npm install vue3-seamless-scroll --save yarn yarn add vue3-seamless-scroll browser <script src="https://unpkg.com/browse/vue3-seamless-scroll@1.0.2/dist/vue3-seamless-scroll.min.js"></script>配置
list无缝滚动列表数据 ,组件内部使用列表长度 。
type: Array
required: true v-model通过v-model控制动画滚动与停止 ,默认开始滚动
type: Boolean
default: true
required: false direction控制滚动方向 ,可选值up ,down,left ,right
type: String
default: “up ”
required: false isWatch开启数据更新监听
type: Boolean,
default: true,
required: false hover是否开启鼠标悬停
type: Boolean
default: false
required: false count动画循环次数 ,默认无限循环
type: Number
default: “infinite ”
required: false limitScrollNum开启滚动的数据量,只有列表长度大于等于该值才会滚动
type: Number,
default: 5,
required: false step步进速度
type: Number,
required: false singleHeight单步运动停止的高度
type: Number,
default: 0,
required: false singleWidth单步运动停止的宽度
type: Number,
default: 0,
required: false singleWaitTime单步停止等待时间(默认值 1000ms)
type: Number,
default: 1000,
required: false isRemUnitsingleHeight and singleWidth 是否开启 rem 度量
type: Boolean
default: true
required: false delay动画延时时间
type: Number,
default: 0,
required: false ease动画效果 ,可以传入贝塞尔曲线数值
type: String | cubic-bezier,
default: “ease-in ”,
required: false copyNum拷贝列表次数 ,默认拷贝一次 ,当父级高度大于列表渲染高度的两倍时可以通过该参数控制拷贝列表次数达到无缝滚动效果
type: Number
default: 1
required: false wheel在开启鼠标悬停的情况下是否开启滚轮滚动 ,默认不开启
type: boolean
default: false
required: false singleLine启用单行横向滚动
type: boolean
default: false
required: false使用
1. 注册组件 全局注册 // **main.js** import { createApp } from vue; import App from ./App.vue; import vue3SeamlessScroll from "vue3-seamless-scroll"; const app = createApp(App); app.use(vue3SeamlessScroll); app.mount(#app); 单文件注册 <script> import { defineComponent } from "vue"; import { Vue3SeamlessScroll } from "vue3-seamless-scroll"; export default defineComponent({ components: { Vue3SeamlessScroll } }) </script> 2. 使用组件我们这里是需要表格内容滚动 ,直接使用组件包裹表格会让表格的表头一起跟着滚走了 ,所以使用上有一点小改动
需要将表格代码再复制一份 ,第一份代码修改css代码将表格的body部分隐藏 ,第二份代码用组件包裹 ,并将其表头部分隐藏; <template> <div class="container"> <el-table class="top-table" :data="tableData" border style="width: 100%;"> <el-table-column prop="type" label="类型" width="120" /> <el-table-column prop="name" label="姓名" /> <el-table-column prop="content" label="内容" /> </el-table> <vue3-seamless-scroll class="seamless" :list="tableData" :hover="true" :step="0.4" :wheel="true" :isWatch="true"> <el-table class="bottom-table" :data="tableData" border style="width: 100%;"> <el-table-column prop="type" label="类型" width="120" /> <el-table-column prop="name" label="姓名" /> <el-table-column prop="content" label="内容" /> </el-table> </vue3-seamless-scroll> </div> </template> <script lang="ts" setup> import { ref } from vue const tableData: any = ref([]) const getData = () => { for (let i = 0; i < 6; i++) { tableData.value.push({ type: `家常菜${i + 1}`, name: `洋茄子炒鸡蛋${i + 1}`, content: `多情键客无情键${i + 1}` }) } } getData() </script> <style scoped> .container { width: 500px; height: 300px; } .seamless { width: 100%; height: 220px; overflow: hidden; } :deep .top-table .el-table__body-wrapper { display: none; } :deep .bottom-table .el-table__header-wrapper { display: none; width: 100%; } </style>这样看效果是不是还行 ,但是 ,还有问题 ,上面示例中我们只造了6条数据,但实际我们项目中表格单页有50条左右数据 ,那改成50条数据看一下效果
这个插件给它用于表格内容滚动已经做出部分改动了 ,现在想要达到我们想要的效果还要去做更多的改动,这针对我们现在的需求不能直接开箱即用 ,到这里我就直接放弃这个方案 ,如何达到我们想要的效果就放到后面有空的时候再看看 ,目前还是以工作效率为主 。当然如果各位有谁研究好了欢迎私信我 ,没有奖励只想看看 。
方案二
方案二就是直接操作滚动条设置一个计时器让它自己滚动 ,这个就是比较简单的前端的基本功
思路
我们只需要声明一个计时器 ,在获取到 table 数据后获取滚动区域 scrollHeight ,在计时器中通过修改 scrollTop 实现滚动条自动滚动
很快码完代码后我们看一下效果
我的代码
<template> <div class="container"> <el-table ref="tableRef" :data="tableData" border style="width: 100%;height: 100%;"> <el-table-column prop="type" label="类型" width="120" /> <el-table-column prop="name" label="姓名" /> <el-table-column prop="content" label="内容" /> </el-table> </div> </template> <script setup> import { ref, onMounted, onUnmounted } from vue let timer = null; let tableRef = ref(null); const scroll = () => { // 在执行新的计时器前将之前的计时器清除 if (timer) clearInterval(timer); let status = true; // 获取表格滚动区域的dom const scrollDom = tableRef.value.$refs.bodyWrapper.getElementsByClassName("el-scrollbar__wrap")[0]; // 增加监听事件鼠标移入停止滚动 scrollDom.addEventListener(mouseover, () => { status = false; }); // 鼠标移出恢复滚动 scrollDom.addEventListener(mouseout, () => { status = true; }); // 设置每秒滚动一行 timer = setInterval(() => { if (status) { // 设置每次滚动的像素 scrollDom.scrollTop += 40; // 当滚动到底部时修改scrollTop回到顶部 if ((scrollDom.scrollHeight - (scrollDom.clientHeight + scrollDom.scrollTop)) < 1 ) { scrollDom.scrollTop = 0; } } }, 1000); } const tableData = ref([]) const getData = () => { for (let i = 0; i < 50; i++) { tableData.value.push({ type: `家常菜${i + 1}`, name: `洋茄子炒鸡蛋${i + 1}`, content: `多情键客无情键${i + 1}` }) } // 要在数据都加载渲染完成后去获取表格的滚动区域dom setTimeout(() => {scroll()}, 1000) } onMounted(() => { getData() }) onUnmounted(() => { // 组件卸载记得清除计时器 if (timer) clearInterval(timer); timer = null; }) </script> <style scoped> .container { width: 500px; height: 310px; } </style>收尾
最后将成品代码封装起来 ,在各个地方调用避免冗余代码 。好了 ,今天这个B班就上到这 。
创心域SEO版权声明:以上内容作者已申请原创保护,未经允许不得转载,侵权必究!授权事宜、对本内容有异议或投诉,敬请联系网站管理员,我们将尽快回复您,谢谢合作!