亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

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

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

背景

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

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

方案一

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

vue3-seamless-scroll

(點(diǎn)擊進(jìn)入官方文檔)

根據(jù)插件描述說是目前組件支持上下左右無縫滾動(dòng),單步滾動(dòng),并且支持復(fù)雜圖標(biāo)的無縫滾動(dòng),支持平臺(tái)與Vue3.0支持平臺(tái)一致。

安裝

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

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

  • v-model

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

  • direction

控制滾動(dòng)方向,可選值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

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

  • limitScrollNum

開啟滾動(dòng)的數(shù)據(jù)量,只有列表長度大于等于該值才會(huì)滾動(dòng)
type: Number,
default: 5,
required: false

  • step

步進(jìn)速度
type: Number,
required: false

  • singleHeight

單步運(yùn)動(dòng)停止的高度
type: Number,
default: 0,
required: false

  • singleWidth

單步運(yùn)動(dòng)停止的寬度
type: Number,
default: 0,
required: false

  • singleWaitTime

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

  • isRemUnit

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

  • delay

動(dòng)畫延時(shí)時(shí)間
type: Number,
default: 0,
required: false

  • ease

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

  • copyNum

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

  • wheel

在開啟鼠標(biāo)懸停的情況下是否開啟滾輪滾動(dòng),默認(rèn)不開啟
type: boolean
default: false
required: false

  • singleLine

啟用單行橫向滾動(dòng)
type: boolean
default: false
required: false

使用

1. 注冊(cè)組件

  • 全局注冊(cè)
// **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');
  • 單文件注冊(cè)
<script>
  import { defineComponent } from "vue";
  import { Vue3SeamlessScroll } from "vue3-seamless-scroll";
   export default defineComponent({
      components: {
        Vue3SeamlessScroll
      }
   })
</script>

2. 使用組件

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

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

方案二

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

思路

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

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

我的代碼

<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í)行新的計(jì)時(shí)器前將之前的計(jì)時(shí)器清除
    if (timer) clearInterval(timer);
    let status = true;
    // 獲取表格滾動(dòng)區(qū)域的dom
    const scrollDom = tableRef.value.$refs.bodyWrapper.getElementsByClassName("el-scrollbar__wrap")[0];

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

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


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

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

</script>

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

收尾

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

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

相關(guān)文章

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

    在vue中寫jsx的幾種方式

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

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

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

最新評(píng)論