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

vue3實(shí)現(xiàn)長(zhǎng)列表虛擬滾動(dòng)的示例代碼

 更新時(shí)間:2025年01月10日 09:45:13   作者:jjw_zyfx  
本文主要介紹了vue3實(shí)現(xiàn)長(zhǎng)列表虛擬滾動(dòng)的示例代碼,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧

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í)聊天軟件

    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)

    這篇文章主要介紹了在vue中實(shí)現(xiàn)嵌套頁(yè)面(iframe),具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧
    2020-07-07
  • Vue Element校驗(yàn)validate的實(shí)例

    Vue Element校驗(yàn)validate的實(shí)例

    這篇文章主要介紹了Vue Element校驗(yàn)validate的實(shí)例,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧
    2020-09-09
  • Vue中兩種生成二維碼(帶logo)并下載方式總結(jié)

    Vue中兩種生成二維碼(帶logo)并下載方式總結(jié)

    與后端生成二維碼相比,前端生成二維碼更具有靈活性,下面這篇文章主要給大家介紹了關(guān)于Vue中兩種生成二維碼(帶logo)并下載的相關(guān)資料,文中通過(guò)代碼介紹的非常詳細(xì),需要的朋友可以參考下
    2024-03-03
  • vue做移動(dòng)端適配最佳解決方案(親測(cè)有效)

    vue做移動(dòng)端適配最佳解決方案(親測(cè)有效)

    這篇文章主要介紹了vue做移動(dòng)端適配最佳解決方案(親測(cè)有效),小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧
    2018-09-09
  • Vue中的百度地圖定位BMap.GeolocationControl的用法

    Vue中的百度地圖定位BMap.GeolocationControl的用法

    BMap.GeolocationControl?是百度地圖API中的一個(gè)類,用于添加地理定位控件到地圖上,以便用戶可以通過(guò)該控件獲取自己的當(dāng)前位置,本文給大家介紹Vue中的百度地圖定位BMap.GeolocationControl的用法,感興趣的朋友跟隨小編一起看看吧
    2023-10-10
  • VUE3項(xiàng)目VITE打包優(yōu)化的實(shí)現(xiàn)

    VUE3項(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-03
  • 對(duì)vue中v-if的常見(jiàn)使用方法詳解

    對(duì)vue中v-if的常見(jiàn)使用方法詳解

    今天小編就為大家分享一篇對(duì)vue中v-if的常見(jiàn)使用方法詳解,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧
    2018-09-09
  • vue實(shí)現(xiàn)前端按鈕組件權(quán)限管理

    vue實(shí)現(xiàn)前端按鈕組件權(quán)限管理

    這篇文章主要為大家介紹了vue實(shí)現(xiàn)前端按鈕組件權(quán)限管理,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2022-09-09
  • vue中正確使用jsx語(yǔ)法的姿勢(shì)分享

    vue中正確使用jsx語(yǔ)法的姿勢(shì)分享

    這篇文章主要給大家介紹了關(guān)于vue中正確使用jsx的相關(guān)資料,JSX就是Javascript和XML結(jié)合的一種格式,React發(fā)明了JSX,利用HTML語(yǔ)法來(lái)創(chuàng)建虛擬DOM,當(dāng)遇到<,JSX就當(dāng)HTML解析,遇到{就當(dāng)JavaScript解析,需要的朋友可以參考下
    2021-07-07

最新評(píng)論