欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

vue3如何實現(xiàn)表格內(nèi)容無縫滾動(又寫了一堆冗余代碼)

 更新時間:2024年04月01日 11:10:43   作者:洋茄子炒雞蛋  
這篇文章主要給大家介紹了關(guān)于vue3如何實現(xiàn)表格內(nèi)容無縫滾動的相關(guān)資料,在Vue3項目中難免會遇到讓列表滾動的需求,文中通過代碼介紹的非常詳細,需要的朋友可以參考下

背景

近期在開發(fā)可視化大屏項目,除去各種echarts圖表和地圖展示之外還有多個表格。現(xiàn)在來了一個需求,需要將大屏中的所有表格設(shè)置為內(nèi)容無縫滾動。
本著程序員的七宗罪原則第一時間推脫了一下,但沒推脫成功。

  • 簡單的在網(wǎng)上查了下適合我們項目的有兩種方案,第一種是使用一款插件 vue3-seamless-scroll
  • 第二種方案是自己寫JS代碼通過計時器去控制表格滾動條自動滾動

方案一

從實際開發(fā)上考慮使用如果有類似功能開箱即用沒什么問題的插件當(dāng)然是最好不過的,能提高不少工作效率達到準(zhǔn)時下班的目的

vue3-seamless-scroll

(點擊進入官方文檔)

根據(jù)插件描述說是目前組件支持上下左右無縫滾動,單步滾動,并且支持復(fù)雜圖標(biāo)的無縫滾動,支持平臺與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

無縫滾動列表數(shù)據(jù),組件內(nèi)部使用列表長度。
type: Array
required: true

  • v-model

通過v-model控制動畫滾動與停止,默認(rèn)開始滾動
type: Boolean
default: true
required: false

  • direction

控制滾動方向,可選值up,down,left,right
type: String
default: “up”
required: false

  • isWatch

開啟數(shù)據(jù)更新監(jiān)聽
type: Boolean,
default: true,
required: false

  • hover

是否開啟鼠標(biāo)懸停
type: Boolean
default: false
required: false

  • count

動畫循環(huán)次數(shù),默認(rèn)無限循環(huán)
type: Number
default: “infinite”
required: false

  • limitScrollNum

開啟滾動的數(shù)據(jù)量,只有列表長度大于等于該值才會滾動
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

單步停止等待時間(默認(rèn)值 1000ms)
type: Number,
default: 1000,
required: false

  • isRemUnit

singleHeight and singleWidth 是否開啟 rem 度量
type: Boolean
default: true
required: false

  • delay

動畫延時時間
type: Number,
default: 0,
required: false

  • ease

動畫效果,可以傳入貝塞爾曲線數(shù)值
type: String | cubic-bezier,
default: “ease-in”,
required: false

  • copyNum

拷貝列表次數(shù),默認(rèn)拷貝一次,當(dāng)父級高度大于列表渲染高度的兩倍時可以通過該參數(shù)控制拷貝列表次數(shù)達到無縫滾動效果
type: Number
default: 1
required: false

  • wheel

在開啟鼠標(biāo)懸停的情況下是否開啟滾輪滾動,默認(rèn)不開啟
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. 使用組件

我們這里是需要表格內(nèi)容滾動,直接使用組件包裹表格會讓表格的表頭一起跟著滾走了,所以使用上有一點小改動
需要將表格代碼再復(fù)制一份,第一份代碼修改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="內(nèi)容" />
        </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="內(nèi)容" />
            </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條數(shù)據(jù),但實際我們項目中表格單頁有50條左右數(shù)據(jù),那改成50條數(shù)據(jù)看一下效果

這個插件給它用于表格內(nèi)容滾動已經(jīng)做出部分改動了,現(xiàn)在想要達到我們想要的效果還要去做更多的改動,這針對我們現(xiàn)在的需求不能直接開箱即用,到這里我就直接放棄這個方案,如何達到我們想要的效果就放到后面有空的時候再看看,目前還是以工作效率為主。當(dāng)然如果各位有誰研究好了歡迎私信我,沒有獎勵只想看看。

方案二

方案二就是直接操作滾動條設(shè)置一個計時器讓它自己滾動,這個就是比較簡單的前端的基本功

思路

我們只需要聲明一個計時器,在獲取到 table 數(shù)據(jù)后獲取滾動區(qū)域 scrollHeight ,在計時器中通過修改 scrollTop 實現(xiàn)滾動條自動滾動

很快碼完代碼后我們看一下效果

我的代碼

<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="內(nèi)容" />
        </el-table>
    </div>
</template>

<script setup>

import { ref, onMounted, onUnmounted } from 'vue'

let timer = null;
let tableRef = ref(null);
const scroll = () => {
    // 在執(zhí)行新的計時器前將之前的計時器清除
    if (timer) clearInterval(timer);
    let status = true;
    // 獲取表格滾動區(qū)域的dom
    const scrollDom = tableRef.value.$refs.bodyWrapper.getElementsByClassName("el-scrollbar__wrap")[0];

    // 增加監(jiān)聽事件鼠標(biāo)移入停止?jié)L動
    scrollDom.addEventListener('mouseover', () => {
        status = false;
    });
    // 鼠標(biāo)移出恢復(fù)滾動
    scrollDom.addEventListener('mouseout', () => {
        status = true;
    });

    // 設(shè)置每秒滾動一行
    timer = setInterval(() => {
        if (status) {
        	// 設(shè)置每次滾動的像素
            scrollDom.scrollTop += 40;
            // 當(dāng)滾動到底部時修改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}`
        })
    }
    // 要在數(shù)據(jù)都加載渲染完成后去獲取表格的滾動區(qū)域dom
    setTimeout(() => {scroll()}, 1000)
}


onMounted(() => {
    getData()
})

onUnmounted(() => {
	// 組件卸載記得清除計時器
    if (timer) clearInterval(timer);
    timer = null;
})

</script>

<style scoped>
.container {
    width: 500px;
    height: 310px;
}
</style>

收尾

最后將成品代碼封裝起來,在各個地方調(diào)用避免冗余代碼。

到此這篇關(guān)于vue3如何實現(xiàn)表格內(nèi)容無縫滾動的文章就介紹到這了,更多相關(guān)vue3表格內(nèi)容無縫滾動內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • vue實現(xiàn)瀑布流布局的示例代碼

    vue實現(xiàn)瀑布流布局的示例代碼

    這篇文章主要為大家詳細介紹了如何利用vue實現(xiàn)簡單的瀑布流布局,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2023-09-09
  • elementui使用el-upload組件實現(xiàn)自定義上傳的詳細步驟

    elementui使用el-upload組件實現(xiàn)自定義上傳的詳細步驟

    upload上傳是前端開發(fā)很常用的一個功能,在Vue開發(fā)中常用的Element組件庫也提供了非常好用的upload組件,這篇文章主要給大家介紹了關(guān)于elementui使用el-upload組件實現(xiàn)自定義上傳的詳細步驟,需要的朋友可以參考下
    2023-12-12
  • 三分鐘讓你快速學(xué)會axios在vue項目中的基本用法(推薦!)

    三分鐘讓你快速學(xué)會axios在vue項目中的基本用法(推薦!)

    Axios是一個基于Promise用于瀏覽器和nodejs的HTTP客戶端,下面這篇文章主要給大家介紹了如何通過三分鐘讓你快速學(xué)會axios在vue項目中的基本用法,文中通過實例代碼介紹的非常詳細,需要的朋友可以參考下
    2022-04-04
  • vue $nextTick實現(xiàn)原理深入詳解

    vue $nextTick實現(xiàn)原理深入詳解

    這篇文章主要介紹了vue $nextTick實現(xiàn)原理深入詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2023-10-10
  • vue實現(xiàn)簡單放大鏡效果

    vue實現(xiàn)簡單放大鏡效果

    這篇文章主要為大家詳細介紹了vue實現(xiàn)簡單放大鏡效果,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2021-08-08
  • vue3 座位選座矩陣布局的實現(xiàn)方法(可點擊選中拖拽調(diào)換位置)

    vue3 座位選座矩陣布局的實現(xiàn)方法(可點擊選中拖拽調(diào)換位置)

    由于公司項目需求需要做一個線上設(shè)置考場相關(guān)的座位布局用于給學(xué)生考機排號考試,實現(xiàn)教室考場座位布局的矩陣布局,可點擊選中標(biāo)記是否有座無座拖拽調(diào)換位置橫向縱向排列,本文給大家分享實現(xiàn)代碼,一起看看吧
    2023-11-11
  • 使用vite兼容低端瀏覽器配置

    使用vite兼容低端瀏覽器配置

    這篇文章主要介紹了使用vite兼容低端瀏覽器配置方式,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2024-05-05
  • Element-UI介紹主題定制、自定義組件和插件擴展的代碼示例

    Element-UI介紹主題定制、自定義組件和插件擴展的代碼示例

    本文介紹了使用Element-UI實現(xiàn)主題定制、自定義組件和擴展插件的方法和實用案例,在開發(fā)過程中,我們可以根據(jù)自己的需求,靈活選擇相關(guān)的技術(shù)手段,并不斷探索和嘗試,以提高開發(fā)效率和用戶體驗,感興趣的朋友跟隨小編一起看看吧
    2024-02-02
  • 在vue中寫jsx的幾種方式

    在vue中寫jsx的幾種方式

    本文主要介紹了在vue中寫jsx的幾種方式,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2022-07-07
  • vue如何使用js對圖片進行點擊標(biāo)注圓點并記錄它的坐標(biāo)

    vue如何使用js對圖片進行點擊標(biāo)注圓點并記錄它的坐標(biāo)

    這篇文章主要介紹了vue如何使用js對圖片進行點擊標(biāo)注圓點并記錄它的坐標(biāo),具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-04-04

最新評論