十万条数据,后端不分页咋办!(如何优化长列表渲染)

十万条数据,后端不分页咋办!(如何优化长列表渲染)

长列表是什么?

  • 我们通常把一组数量级很大的数据叫做长列表,比如渲染一组上千条的数据,我们以数组的形式拿到这些信息,然后遍历渲染在页面上;

长列表应该如何渲染?

  • 面对这种大量的数据我们通常会采取分页拉取的形式来优化用户体验,比如直截了当的分页器,或者无限滚动,再配合懒加载等方式,这样能够满足大部分长列表的场景
  • 但是当我们面对的数据量巨大且无法分页拉取时,上面说的方法就不好用了;在一个移动端的页面上呈现成千上万个dom,除了请求时的挑战,渲染时对于用户的设备性能也是一个极大的考验。
  • 我尝试在一个页面中渲染近万条数据
  • img
  • 最直观可以看到的是,在真实列表中产生了十万多个节点。虽然我们创建DOM这件事本身很简单,但是每个dom都会增加页面在内存、布局、样式、绘制方面额外的成本。如果网页的dom过多会导致低端设备变得卡顿甚至无法使用。(Admittedly, DOM nodes themselves are cheap, but they are not free, as each of them adds extra cost in memory, layout, style and paint. Low-end devices will get noticeably slower if not completely unusable if the website has too big of a DOM to manage.)
  • 在这里尝试一种虚拟列表的渲染形式,明显的可以看到,在页面中只产生了几百个dom节点,大大提升了页面的渲染性能
  • img

虚拟列表的实现原理

  • 虚拟列表实际上就是一种按需渲染的操作。我们在渲染上万条数据时,只需要渲染可视区当中的元素,当页面发生滚动时,监听元素并进行替换,从而达到在上万上亿条数据面前,被页面渲染的也只有不过几百个节点,达到优化长列表大数据渲染的目的。

  • [外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-kUw9MHbB-1684195828128)(https://ask.qcloudimg.com/http-save/4611443/c7b08e5f613255e088e8ff99b98377f9.gif)]

  • 如何实现一个虚拟列表,实际上就是在首屏加载的时候,只加载 可视区域 内需要的元素,当页面滚动时,再动态计算需要被渲染的元素,删除掉消失在视窗中的元素,保持总数一致。

  • 
    
  • 前面我们看到在虚拟列表渲染中,只渲染了可视区的数据,所以为了让页面能够正常的滚动,我们需要一个占位的元素,在上面代码的DOM结构中mod-wraper充当可视区的角色,mod-phantom是我们的占位元素,用来形成滚动条,mod-realList才是我们真正渲染出来的元素列表。我们需要定义一些变量来计算该出现在视窗中的数据。

  • // 假定需要渲染的数据为 listData[] , 每个元素的高度为 itemHight, 占位Dom的滚动距离为scrollTop; 
    const wrapperHight = X; //视窗高度 
    const seatListHeight = list.length * itemHight; //占位Dom高度 
    const visibleCount = Math.ceil(wrapperHight / itemHeight); // 可视元素数量 
    const startIndex = Math.floor(scrollTop / itemHeight); // 起始元素 
    const endIndex = startIndex + visibleCount; // 终止元素 
    const startOffset = scrollTop; //列表偏移量 
    const visibleData = listData.slice(startIndex, endIndex); //可视区域数据
    
  • 我们可以利用视窗的高度计算出此时视窗中的开始元素与结束元素,对listData进行裁剪。监听mod-phantom的滚动条数据对mod-realList进行translate,使页面看起来实现了真正的滚动。

  • [外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-jmgs0of5-1684195828129)(https://ask.qcloudimg.com/http-save/4611443/40e095a671c55d55cb5ba818f21a4ed8.gif)]

  • 真实的使用案例当中,我们不会只是渲染一个列表,还会存在其他元素以及宽高的不缺定性,那我们就需要设置更多的变量去进行计算。比如页面中的头部和底部数据,封装好的组件不一定能满足我们的需求,所以只有掌握了才能更好的应用于开发当中。

优化思路

  • 由于虚拟列表是实时生成dom,所以有一定回流和重绘的成本,并且由于我们用监听滚动条来实现‘假装滚动’,Rander进程无法及时更新视图,所以在用户滑动过快时会产生页面上只剩背景的问题,我们可以通过提前渲染一些元素来缓解这个问题,比如提前渲染100条,这样用户滑得再快也不会看到白屏了。
  • 说到了提前渲染,我们也可以使用这种方式去动态监听不定宽高的列表场景。

适用场景

  • 说了这么多感觉虚拟列表是不是很厉害,其实通过实践发现,在几百条数据的情况下,虚拟列表与真实Dom的渲染速率毫无差别。所以我们这里所说的长列表,是几千几万条数据的情况下。
  • 转载至 https://cloud.tencent.com/developer/article/2064523

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/22685.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

正点原子ALPHA开发板核心资源分析

目录 正点原子ALPHA开发板核心资源分析I.MX6ULL实物图对比SOC 主控芯片(MCIMX6Y2CVM08AB)NAND FLASHEMMCDDR3L 正点原子ALPHA开发板核心资源分析 I.MX6ULL实物图对比 I.MX6ULL NAND BTB 接口核心板资源图与 I.MX6ULL EMMC BTB 接口核心板资源图如上图&a…

电商项目9:新增商品

电商项目9:新增商品 1、前端1.1、修复前端组件通信问题1.2、引入其他前端代码1.3、会员等级列表1.4、当前分类关联的所有品牌 2、后端2.1、会员系统搭建(注册与发现)2.2、当前分类关联的所有品牌2.3、获取分类下所有分组&关联属性 1、前端…

shell sed命令

提示:文章写完后,目录可以自动生成,如何生成可参考右边的帮助文档 文章目录 sed 命令sed 编辑器sed 的工作流程的三个过程命定格式常用选项常用操作 实验操作打印内容使用地址删除行替换插入 sed 命令 sed 编辑器 sed是一种流编辑器&#x…

听我一句劝,别去外包,干了6年,废了....

先说一下自己的情况,大专生,18年通过校招进入湖南某软件公司,干了接近6年的功能测试,今年年初,感觉自己不能够在这样下去了,长时间呆在一个舒适的环境会让一个人堕落!而我已经在一个企业干了6年的功能测试&…

中国移动董宁:深耕区块链的第八年,我仍期待挑战丨对话MVP

区块链技术对于多数人来说还是“新鲜”的代名词时,董宁已经成为这项技术的老朋友。 董宁2015年进入区块链领域,现任中国移动研究院技术总监、区块链首席专家。作为“老友”,董宁见证了区块链技术多个爆发式增长和平稳发展的阶段,…

Doxygen 源码分析: SymbolMap类

2023-05-21 10:59:35 ChrisZZ imzhuofoxmailcom Hompage https://github.com/zchrissirhcz 文章目录 1. Doxygen 版本2. SymbolMap 类概要3. 添加符号: SymbolMap<T>::add()4. 删除符号: SymbolMap<T>::remove()5. 符号查找: SymbolMap<T>::find()6. 哪里用了…

什么是半实物仿真平台自动驾驶半实物仿真平台有哪些?

文章目录 半实物仿真平台介绍自动驾驶半实物仿真平台介绍1.CARLA2.AirSim3.LGSVL Simulator 半实物仿真平台介绍 半实物仿真平台是一种综合利用虚拟仿真和实际硬件设备的仿真系统。它将虚拟环境和真实硬件设备结合起来&#xff0c;旨在提供更真实、更准确的仿真体验。 在半实…

基于html+css的图展示90

准备项目 项目开发工具 Visual Studio Code 1.44.2 版本: 1.44.2 提交: ff915844119ce9485abfe8aa9076ec76b5300ddd 日期: 2020-04-16T16:36:23.138Z Electron: 7.1.11 Chrome: 78.0.3904.130 Node.js: 12.8.1 V8: 7.8.279.23-electron.0 OS: Windows_NT x64 10.0.19044 项目…

Boundary IoU:Improving Object-Centric Image Segmentation Evaluation总结笔记

Boundary IoU:Improving Object-Centric Image Segmentation Evaluation&#xff08;边界Iou&#xff1a;改进以对象为中心的图像分割评价&#xff09; 目录 一、论文出发点 二、论文核心思想 三、相关工作 四、敏感度分析 五、Boundary IoU定义和实验证明 六、应用 七…

基于Gabor-小波滤波深度图表面法线的特征提取算法【通过正常Gabor-小波的直方图进行2D或3D特征提取】研究(Matlab代码实现)

&#x1f4a5;&#x1f4a5;&#x1f49e;&#x1f49e;欢迎来到本博客❤️❤️&#x1f4a5;&#x1f4a5; &#x1f3c6;博主优势&#xff1a;&#x1f31e;&#x1f31e;&#x1f31e;博客内容尽量做到思维缜密&#xff0c;逻辑清晰&#xff0c;为了方便读者。 ⛳️座右铭&a…

Redis+Lua脚本防止超卖

超卖就是因为查询库存和扣减库存两个操作不是原子性操作&#xff0c;通过rua脚本执行这两个操作可以保证这两个操作原子性 判断库存量是不是大于等于1&#xff0c;如果大于等于1对库存减1&#xff0c;否则就不去减库存 StringBuilder sb new StringBuilder();sb.append("…

【JAVA进阶】Stream流

&#x1f4c3;个人主页&#xff1a;个人主页 &#x1f525;系列专栏&#xff1a;JAVASE基础 目录 1.Stream流的概述 2.Stream流的获取 3.Stream流的常用方法 1.Stream流的概述 什么是Stream流&#xff1f; 在Java 8中&#xff0c;得益于Lambda所带来的函数式编程&#xff0…

使用go语言构建区块链 Part2.工作量证明

英文源地址 简介 在上一篇文章中, 我们构建了一个非常简单的数据结构, 这是区块链数据库的本质.并且我们可以通过它们之间的链式关系来添加区块: 每个区块都链接到前一个区块.哎, 我们的区块链实现有一个重大缺陷: 向链中添加区块既容易又便捷. 区块链和比特币的关键之一是增…

面对当下各种不确定性,如何面对,每天很忙碌,不慌

&#xff08;点击即可收听&#xff09; 疫情时期,都难,疫情之后,发现还更难 随着互联网的热度的下降,各大小公司纷纷勒紧裤腰带,受打击最大的无疑是底层打工人 每天一打开手机,会发现,一些大厂裁员信息霸榜头条,年龄也是一道坎 刚刚看到一个大v发的&#xff1a; 一个原先是跨国…

如何在 OpenSUSE 上安装 VirtualBox 7?

VirtualBox 是一款开源的虚拟化软件&#xff0c;允许用户在单个计算机上运行多个操作系统。本文将详细介绍如何在 OpenSUSE 上安装 VirtualBox 7。以下是安装过程的步骤&#xff1a; 步骤一&#xff1a;下载 VirtualBox 7 首先&#xff0c;我们需要下载 VirtualBox 7 的安装包…

真题详解(语法分析输入记号流)-软件设计(八十)

真题详解&#xff08;求叶子结点数&#xff09;-软件设计&#xff08;七十九)https://blog.csdn.net/ke1ying/article/details/130787349?spm1001.2014.3001.5501 极限编程XP最佳实践&#xff1a; 测试先行、 按日甚至按小时为客户提供可运行的版本。 组件图的 插座 和插头…

Pytorch的CNN,RNNLSTM

CNN 拿二维卷积举例&#xff0c;我们先来看参数 卷积的基本原理&#xff0c;默认你已经知道了&#xff0c;然后我们来解释pytorch的各个参数&#xff0c;以及其背后的计算过程。 首先我们先来看卷积过后图片的形状的计算&#xff1a; 参数&#xff1a; kernel_size &#xff…

使用Linkage Mapper工进行物种分布建模的步骤详解(含实际案例分析)

✅创作者:陈书予 🎉个人主页:陈书予的个人主页 🍁陈书予的个人社区,欢迎你的加入: 陈书予的社区 🌟专栏地址: Linkage Mapper解密数字世界链接 文章目录 引言:一、介绍二、数据准备2.1 物种分布数据获取2.2 环境变量数据获取2.3 数据预处理

车道线检测

前言 目前&#xff0c;车道线检测技术已经相当成熟&#xff0c;主要应用在自动驾驶、智能交通等领域。下面列举一些当下最流行的车道线检测方法&#xff1a; 基于图像处理的车道线检测方法。该方法是通过图像处理技术从摄像头传回的图像中提取车道线信息的一种方法&#xff0c…

FreeRTOS(6)----软件定时器

一&#xff0c;软件定时器概述 软件定时器允许设置一段时间&#xff0c;当设定的时间到达之后就会执行指定的功能函数&#xff0c;被定时器调用的这个函数叫做定时器的回调函数。回调函数的两次执行间隔叫做定时器的定时周期。 二&#xff0c;回调函数的注意事项 回调函数是…