vue3實(shí)現(xiàn)長(zhǎng)列表虛擬滾動(dòng)的示例代碼
1、直接看代碼
<template> <!--定義一個(gè)大容器,此容器可以滾動(dòng)--> <div class="view" ref="viewRef" @scroll="handleScroll"> <!--定義一個(gè)可以撐滿整個(gè)data的容器,主要是讓父元素滾動(dòng)起來(lái)--> <div class="phantom" :style="{ height: `${itemSize * data.length}px` }"></div> <!--顯示元素列表 因?yàn)閘ist也是絕對(duì)定位,當(dāng)父元素進(jìn)行滾動(dòng)時(shí),父元素需要平移來(lái)表示滾動(dòng)(實(shí)際是看到的是沒(méi)有滾動(dòng))--> <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'; //模擬請(qǐng)求回來(lái)的數(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 // 移動(dòng)的距離 const translateLen = ref(0); // 綁定的元素 const viewRef = ref(null); // 從那條數(shù)據(jù)開(kāi)始取值 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)); // 滾動(dòng)起來(lái)后需要處理的顯示的開(kāi)始位置和要移動(dòng)的距離 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 { /* 必須要絕對(duì)定位 */ position: absolute; width: 100%; background-color: pink; } .list { /* 必須要絕對(duì)定位 */ position: absolute; } </style>
顯示的結(jié)果如下:
當(dāng)向下滾動(dòng)時(shí):
再向上滾動(dòng):
到此這篇關(guān)于vue3實(shí)現(xiàn)長(zhǎng)列表虛擬滾動(dòng)的示例代碼的文章就介紹到這了,更多相關(guān)vue3 長(zhǎng)列表虛擬滾動(dòng)內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
websocket+Vuex實(shí)現(xiàn)一個(gè)實(shí)時(shí)聊天軟件
這篇文章主要利用websocked 建立長(zhǎng)連接,利用Vuex全局通信的特性,以及watch,computed函數(shù)監(jiān)聽(tīng)消息變化,并驅(qū)動(dòng)頁(yè)面變化實(shí)現(xiàn)實(shí)時(shí)聊天,感興趣的可以了解一下2021-08-08在vue中實(shí)現(xiàn)嵌套頁(yè)面(iframe)
這篇文章主要介紹了在vue中實(shí)現(xiàn)嵌套頁(yè)面(iframe),具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2020-07-07Vue Element校驗(yàn)validate的實(shí)例
這篇文章主要介紹了Vue Element校驗(yàn)validate的實(shí)例,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2020-09-09Vue中兩種生成二維碼(帶logo)并下載方式總結(jié)
與后端生成二維碼相比,前端生成二維碼更具有靈活性,下面這篇文章主要給大家介紹了關(guān)于Vue中兩種生成二維碼(帶logo)并下載的相關(guān)資料,文中通過(guò)代碼介紹的非常詳細(xì),需要的朋友可以參考下2024-03-03vue做移動(dòng)端適配最佳解決方案(親測(cè)有效)
這篇文章主要介紹了vue做移動(dòng)端適配最佳解決方案(親測(cè)有效),小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2018-09-09Vue中的百度地圖定位BMap.GeolocationControl的用法
BMap.GeolocationControl?是百度地圖API中的一個(gè)類,用于添加地理定位控件到地圖上,以便用戶可以通過(guò)該控件獲取自己的當(dāng)前位置,本文給大家介紹Vue中的百度地圖定位BMap.GeolocationControl的用法,感興趣的朋友跟隨小編一起看看吧2023-10-10VUE3項(xiàng)目VITE打包優(yōu)化的實(shí)現(xiàn)
本文主要介紹了VUE3項(xiàng)目VITE打包優(yōu)化的實(shí)現(xiàn),包括使用視圖分析工具、路由懶加載、第三方庫(kù)CDN引入、gzip壓縮、按需引入第三方庫(kù)、TreeShaking、剔除console和debugger、分包策略和圖片壓縮等,具有一定的參考價(jià)值,感興趣的可以了解一下2025-03-03vue實(shí)現(xiàn)前端按鈕組件權(quán)限管理
這篇文章主要為大家介紹了vue實(shí)現(xiàn)前端按鈕組件權(quán)限管理,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2022-09-09