vue3實(shí)現(xiàn)長列表虛擬滾動的示例代碼
1、直接看代碼
<template>
<!--定義一個大容器,此容器可以滾動-->
<div class="view" ref="viewRef" @scroll="handleScroll">
<!--定義一個可以撐滿整個data的容器,主要是讓父元素滾動起來-->
<div class="phantom" :style="{ height: `${itemSize * data.length}px` }"></div>
<!--顯示元素列表 因?yàn)閘ist也是絕對定位,當(dāng)父元素進(jìn)行滾動時,父元素需要平移來表示滾動(實(shí)際是看到的是沒有滾動)-->
<div class="list" :style="{ transform: `translateY(${translateLen}px)` }">
<!--顯示每條數(shù)據(jù)-->
<div v-for="item in visibleList" :style="{ height: `${itemSize}px` }">
{{ item }}
</div>
</div>
</div>
</template>
<script setup>
import {computed, reactive, ref} from 'vue';
//模擬請求回來的數(shù)據(jù)
const data = reactive((() => {
const arr = [];
for (let i = 0; i < 1000000; i++) arr[i] = i;
return arr;
})());
// 每條數(shù)據(jù)占據(jù)的高度像素值
const itemSize = 40
// 移動的距離
const translateLen = ref(0);
// 綁定的元素
const viewRef = ref(null);
// 從那條數(shù)據(jù)開始取值
const start = ref(0);
// 可視區(qū)顯示的條數(shù)
const visibleCount = computed(() => Math.ceil(viewRef.value?.clientHeight / itemSize));
// 可視區(qū)顯示的數(shù)據(jù)內(nèi)容(即需要渲染的所有數(shù)據(jù)內(nèi)容)
const visibleList = computed(() => data.slice(start.value, start.value + visibleCount.value));
// 滾動起來后需要處理的顯示的開始位置和要移動的距離
const handleScroll = () => {
const scrollTop = viewRef.value.scrollTop;
start.value = Math.floor(scrollTop / itemSize);
console.log("scrollTop==>", scrollTop)
translateLen.value = scrollTop
console.log("translateLen.value==>", translateLen.value)
}
</script>
<style scoped>
.view {
position: relative;
height: 400px;
width: 400px;
overflow: auto;
}
.phantom {
/* 必須要絕對定位 */
position: absolute;
width: 100%;
background-color: pink;
}
.list {
/* 必須要絕對定位 */
position: absolute;
}
</style>
顯示的結(jié)果如下:

當(dāng)向下滾動時:

再向上滾動:

到此這篇關(guān)于vue3實(shí)現(xiàn)長列表虛擬滾動的示例代碼的文章就介紹到這了,更多相關(guān)vue3 長列表虛擬滾動內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
websocket+Vuex實(shí)現(xiàn)一個實(shí)時聊天軟件
這篇文章主要利用websocked 建立長連接,利用Vuex全局通信的特性,以及watch,computed函數(shù)監(jiān)聽消息變化,并驅(qū)動頁面變化實(shí)現(xiàn)實(shí)時聊天,感興趣的可以了解一下2021-08-08
在vue中實(shí)現(xiàn)嵌套頁面(iframe)
這篇文章主要介紹了在vue中實(shí)現(xiàn)嵌套頁面(iframe),具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2020-07-07
Vue Element校驗(yàn)validate的實(shí)例
這篇文章主要介紹了Vue Element校驗(yàn)validate的實(shí)例,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2020-09-09
Vue中兩種生成二維碼(帶logo)并下載方式總結(jié)
與后端生成二維碼相比,前端生成二維碼更具有靈活性,下面這篇文章主要給大家介紹了關(guān)于Vue中兩種生成二維碼(帶logo)并下載的相關(guān)資料,文中通過代碼介紹的非常詳細(xì),需要的朋友可以參考下2024-03-03
Vue中的百度地圖定位BMap.GeolocationControl的用法
BMap.GeolocationControl?是百度地圖API中的一個類,用于添加地理定位控件到地圖上,以便用戶可以通過該控件獲取自己的當(dāng)前位置,本文給大家介紹Vue中的百度地圖定位BMap.GeolocationControl的用法,感興趣的朋友跟隨小編一起看看吧2023-10-10
VUE3項目VITE打包優(yōu)化的實(shí)現(xiàn)
本文主要介紹了VUE3項目VITE打包優(yōu)化的實(shí)現(xiàn),包括使用視圖分析工具、路由懶加載、第三方庫CDN引入、gzip壓縮、按需引入第三方庫、TreeShaking、剔除console和debugger、分包策略和圖片壓縮等,具有一定的參考價值,感興趣的可以了解一下2025-03-03
vue實(shí)現(xiàn)前端按鈕組件權(quán)限管理
這篇文章主要為大家介紹了vue實(shí)現(xiàn)前端按鈕組件權(quán)限管理,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2022-09-09

