百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 技术文章 > 正文

Vue 项目性能杀手锏:虚拟列表,让你的万级数据列表流畅如丝!

zhezhongyun 2024-12-04 17:04 32 浏览

面对海量数据渲染,即使是强大的 Vue 也难免会遇到性能瓶颈,卡顿、掉帧等问题接踵而至。今天,我们就来聊聊如何利用虚拟列表这一“黑科技”,解决 Vue 中万级数据列表的勾选卡顿问题,让你的列表性能飞起来!

海量数据渲染之痛:卡顿、崩溃、用户体验差

当数据量达到上万条甚至更多时,传统的列表渲染方式会将所有数据一次性加载并渲染到页面上,这会带来一系列问题:

  • 浏览器卡顿: 大量的 DOM 节点操作,会占用大量的 CPU 资源,导致浏览器卡顿甚至崩溃。
  • 页面加载缓慢: 首次渲染时间过长,用户需要等待很长时间才能看到列表内容。
  • 操作卡顿: 列表滚动、勾选等操作,都会变得非常卡顿,严重影响用户体验。

虚拟列表:以一敌万的性能优化利器

虚拟列表的核心思想是:只渲染可视区域内的数据,非可视区域的数据不进行渲染,从而大大减少 DOM 节点数量,提高渲染效率。

Vue 中如何实现虚拟列表?

1. 核心思路

  • 计算可视区域的高度和每个列表项的高度。
  • 根据可视区域的高度和滚动位置,计算出需要渲染的列表项的起始索引和结束索引。
  • 只渲染起始索引和结束索引之间的列表项,并通过 CSS 技巧,将这些列表项定位到正确的位置。
  • 监听列表滚动事件,动态更新渲染的列表项。

2. 示例代码

<template>
  <div class="virtual-list" @scroll="handleScroll">
    <div class="list-viewport" :style="{ height: `${viewportHeight}px` }">
      <div class="list-container" :style="{ transform: `translateY(${startIndex * itemHeight}px)` }">
        <div v-for="(item, index) in visibleData" :key="index" class="list-item" :style="{ height: `${itemHeight}px` }">
          <input type="checkbox" v-model="item.checked">
          {{ item.label }}
        </div>
      </div>
    </div>
  </div>
</template>

<script>
export default {
  data() {
    return {
      dataList: [], //  所有数据
      visibleData: [], //  可视区域数据
      viewportHeight: 0, //  可视区域高度
      itemHeight: 50, //  每个列表项高度
      startIndex: 0, //  起始索引
      endIndex: 0, //  结束索引
    };
  },
  mounted() {
    this.viewportHeight = this.$el.clientHeight;
    this.generateData(10000); //  生成 10000 条数据
  },
  methods: {
    //  生成模拟数据
    generateData(count) {
      for (let i = 0; i < count; i++) {
        this.dataList.push({
          label: `Item ${i}`,
          checked: false,
        });
      }
      this.updateVisibleData();
    },
    //  更新可视区域数据
    updateVisibleData() {
      this.startIndex = Math.floor(this.$el.scrollTop / this.itemHeight);
      this.endIndex = Math.min(this.startIndex + Math.ceil(this.viewportHeight / this.itemHeight) + 1, this.dataList.length);
      this.visibleData = this.dataList.slice(this.startIndex, this.endIndex);
    },
    //  处理滚动事件
    handleScroll() {
      this.updateVisibleData();
    },
  },
};
</script>

3. 源码解析

  • handleScroll 方法监听列表滚动事件,并在每次滚动时调用 updateVisibleData 方法。
  • updateVisibleData 方法计算可视区域数据的起始索引和结束索引,并更新 visibleData 数组。
  • v-for 指令只渲染 visibleData 数组中的数据,从而减少 DOM 节点数量。
  • :style 属性动态设置列表容器的 transform 属性,将可视区域数据定位到正确的位置。

总结

虚拟列表是解决海量数据渲染性能问题的利器,使用虚拟列表可以显著提高列表的渲染效率和用户体验。在 Vue 项目中,我们可以借助虚拟列表组件或自行实现虚拟列表逻辑,优化列表性能,打造丝滑流畅的用户体验!

#头条创作挑战赛##程序员##深中通道今日正式通车试运营#

相关推荐

写作排版简单三步就行-工具篇(作文排版编辑软件)

和我们工作中日常word排版内部交流不同,这篇教程介绍的写作排版主要是用于“微信公众号、头条号”网络展示。写作展现的是我的思考,排版是让写作在网格上更好地展现。在写作上花费时间是有累积复利优势的,在排...

CSS继承的元素属性小总结(css 继承性)

所有元素可继承:visibility和cursor内联元素和块级元素可继承:letter-spacingword-spacingwhite-spaceline-heightcolorfontfont-...

Cube 技术解读 | Cube 小程序技术详解

作者:曾维宏(恒实)“本文为《Cube技术解读》系列第三篇文章,之前上线的《支付宝新一代动态化技术架构与选型综述》《Cube卡片技术栈解读》欢迎大家回顾。”小程序作为动态化或者跨端开发的一种技术栈...

“战斗民族”这样为新生儿检查?(战斗民族)

<fontface="近日,一条被称为“俄罗斯新生儿检查”的视频在微博疯传,视频中检查者粗鲁的动作让网友们纷纷感染“怪不得是战斗民族”。视频真实性有待考证,但宝宝出生后确实需要马不停蹄地做一系...

实测,大模型谁更懂数据可视化?(实测,大模型谁更懂数据可视化技术)

大家好,我是Ai学习的老章看论文时,经常看到漂亮的图表,很多不知道是用什么工具绘制的,或者很想复刻类似图表。实测,大模型LaTeX公式识别,出乎预料前文,我用Kimi、Qwen-3-235B...

「Python爬虫」:破解网站字体加密和反反爬虫

前言:字体反爬,也是一种常见的反爬技术,例如58同城,猫眼电影票房,汽车之家,天眼查,实习僧等网站。这些网站采用了自定义的字体文件,在浏览器上正常显示,但是爬虫抓取下来的数据要么就是乱码,要么就是变成...

转录组及可视化分析——样本间相关性绘图

背景介绍在进行正式的转录组分析之前,一般可以先对样本的相关性进行绘图,用于观察各个组之间或组内样本的相关性。数据介绍数据的话我们采用的是送样测序公司反馈给我们的gene_count文件,格式如下:...

阿里巴巴矢量图标库 iconfont 的使用方法

xx-blog主题使用的图标库是阿里巴巴的iconfont,因此这里介绍一下此主题库的用法。首先去iconfont主题库,注册一个账号,然后就可以找自己喜欢的图标了,找到后点击添加购物车,就回到了右侧...

五行取名(五行取名的正确方法)

1、五行的分类原则以方位来论:东方属木;南方属火;西方属金;北方属水;中央属土。以季节来论:春季属木;夏季属火;秋季属金;冬季属水;季末属土。以气候来论:风属木;暑属火;燥属金;寒属水;湿属土。以颜色...

4K显示器软件界面字体过小解决方法

用4K显示器(win10或者win11下)的朋友会发现一些软件并不能随着系统的字体放大而放大字体,用起来很不方便。譬如常用的ps或者行业专用软件。笔者经过摸索,发现这样设置一下可以解决。下面以Psc...

VBA之Word应用:利用Range方法进行字体及对齐方式设置

《VBA之Word应用》(版权10178982),是我推出第八套教程,教程是专门讲解VBA在Word中的应用,围绕“面向对象编程”讲解,首先让大家认识Word中VBA的对象,以及对象的属性、方法,然后...

办公小技巧:告别侵权 PPT字体自己造

很多朋友还不知道,我们每天面对的字体都是有版权保护的,如果对这方面的内容不了解,一不小心就可能造成侵权。那么我们在日常设计PPT文稿的时候,如何避免字体侵权呢?首先我们得懂得如何查看版权信息,另外还需...

显示器颜色显示有偏差?你校准过吗?

编辑:晴晨购物、拍照、做视频、玩游戏……看似不一样的操作都怕一件事:颜色有偏差。购物时商品颜色有出入,毫不知情的情况下把责任推给了商家,那么拍照、做视频、玩游戏呢?我们先来看看某网友的诉苦:“我的是台...

设计字体那些事(设计字体种类大全图)

做设计几年,平均每年都能遇见好多因为字体侵权的事情,今天就结合我自己的经验和了解简单介绍下字体那些事#毒角SHOW角角用了这款字体,竟被送律师函赔偿10万https://www.douyin.com...

LCD智能显示模块-绘图板(lcd显示模块流程图)

TOPWAY智能模块(SmartLCD)是专门为工业显示应用而设计的TFT液晶显示模块。我司自主研发的界面编辑软件RGTools/SGTools提供了18个控件,通过些控件能实现丰富的显...