vue之虚拟滚动

一、解决的问题

对于大量数据的懒加载,我们可以使用虚拟滚动的技术。虚拟滚动的原理是只渲染可视区域内的数据,当用户滚动时,动态计算并渲染新的可视数据,从而实现大数据量的流畅滚动。

在Vue中,我们可以使用第三方库如vue-virtual-scroller来实现虚拟滚动。

二、实现方式

首先,安装vue-virtual-scroller库:

复制代码
npm install vue-virtual-scroller

html

复制代码
<template>
  <div>
    <RecycleScroller
      class="scroller"
      :items="dataList"
      :item-size="30"
      key-field="id"
    >
      <template #default="{ item }">
        <div class="item">
          {{ item.content }}
        </div>
      </template>
    </RecycleScroller>
  </div>
</template>

<script>
import { RecycleScroller } from 'vue-virtual-scroller'
import 'vue-virtual-scroller/dist/vue-virtual-scroller.css'

export default {
  components: {
    RecycleScroller
  },
  data() {
    return {
      dataList: []
    }
  },
  created() {
    this.fetchData();
  },
  methods: {
    fetchData() {
      // 调用API接口,获取数据
      axios.get('/api/data')
        .then(response => {
          this.dataList = response.data;
        })
        .catch(error => {
          console.error(error);
        });
    }
  }
}
</script>

<style>
.scroller {
  height: 100%;
  overflow-y: auto;
}

.item {
  height: 30px;
  line-height: 30px;
}
</style>

三、属性api

RecycleScroller组件的主要属性如下:

  • items:数组,需要渲染的数据列表。

  • item-size:数字,每个列表项的大小(高度或宽度)。

  • key-field:字符串,每个列表项的唯一标识字段。

  • page-mode:布尔值,是否使用页面模式。在页面模式下,滚动容器是document.documentElement,否则是RecycleScroller自身。

  • direction:字符串,滚动方向,可以是vertical(垂直)或horizontal(水平)。

  • buffer:数字,渲染缓冲区大小。增大这个值可以减少滚动时的列表项闪烁,但会增加内存占用。

  • prerender:数字,预渲染的列表项数量。

  • emitUpdate:布尔值,是否在列表项更新时触发update事件。

以下是一个RecycleScroller的示例:

复制代码
<RecycleScroller
  class="scroller"
  :items="dataList"
  :item-size="50"
  key-field="id"
  page-mode
  direction="vertical"
  :buffer="200"
  :prerender="10"
  emitUpdate
>
  <template #default="{ item }">
    <div class="item">
      {{ item.content }}
    </div>
  </template>
</RecycleScroller>

以上代码中,RecycleScroller会渲染dataList中的数据,每个列表项的高度是50px,使用页面模式和垂直滚动,渲染缓冲区大小是200px,预渲染10个列表项,并在列表项更新时触发update事件。

相关推荐
陈广亮5 分钟前
工具指南7-Unix时间戳转换工具
前端
NGBQ1213811 分钟前
Adobe-Premiere-Pro-2026-26.0.2.2-m0nkrus 全解析:专业视频编辑软件深度指南
前端·adobe·音视频
北城笑笑13 分钟前
Chrome:Paused in debugger 的踩坑实录:问题排查全过程与终极解决方案( 在调试器中暂停 )
前端·chrome
haorooms15 分钟前
Promise.try () 完全指南
前端·javascript
kyriewen16 分钟前
闭包:那个“赖着不走”的家伙,到底有什么用?
前端·javascript·ecmascript 6
斌味代码19 分钟前
el-popover跳转页面不隐藏,el-popover销毁
前端·javascript·vue.js
该怎么办呢19 分钟前
cesium核心代码学习-01项目目录及其基本作用
前端·3d·源码·webgl·cesium·webgis
踩着两条虫26 分钟前
AI 驱动的 Vue3 应用开发平台 深入探究(十九):CLI与工具链之Create VTJ CLI 参考
前端·ai编程·vite
嫂子的姐夫29 分钟前
040-spiderbuf第C8题
javascript·爬虫·python·js逆向·逆向
天下无贼!37 分钟前
【Python】2026版——FastAPI 框架快速搭建后端服务
开发语言·前端·后端·python·aigc·fastapi