当前位置: 首页 > news >正文

前端列表数据太多导致页面卡顿就这么处理

前端列表数据太多页面卡顿就这么处理

      • 实际场景
      • 什么是虚拟列表
      • 虚拟列表实现原理
      • 实战中虚拟列表的问题及相应解决方案

实际场景

首先看以下两个实际场景:

场景一:有一个数据列表,数据量非常大且每一个数据项都有几十列甚至更多,且后端未做分页,一次将所有的数据返回到前端,此时全部渲染用户需要等待很长时间才能看到页面,甚至用户的滑动操作都会比较卡。
场景二:同样有一个数据量非常大的数据列表,后端做了分页,前端一次请求50条数据,页面首次渲染非常快,上拉加载也很流畅。随着用户一直上拉加载,页面上的dom越来越多,逐渐的上拉加载就变得卡顿了。

在以上两个场景中就是我们平时所说的长列表无法避免的问题,主要原因是页面中的dom太多导致渲染卡顿。目前最优的方案是虚拟列表

什么是虚拟列表

概念:虚拟列表是一种优化长列表加载性能的技术,通过只渲染用户当前可见的元素,极大地提高了用户体验和应用性能。

虚拟列表实现原理

虚拟列表的实现原理主要是对列表的可视区域进行渲染,而对非可见区域不渲染或部分渲染。

  1. 首先需要准备两个数据源
    • 第一个是原始数据源,用于存放所有的应该渲染到页面上的数据
    • 第二个是部分数据源,用于存放要渲染到可视区域和部分不可视区域的数据,以下是部分数据源生成方式:

      部分数据源依赖原始数据源和当前可视区域生成,假设我们期望页面最多渲染100条实际数据首次渲染时,我们对原始数据进行遍历

      1. 若原始数据源长度小于100条,则原始数据源全部加到部分数据源数组中
      2. 若原始数据源长度大于100条,则原始数据源中前100条数据加入到部分数据源中,第100条以后的数据以 {} 的形式加入到部分数据源中。
      • 特别说明:部分数据源中添加 {}目的时为了占位,即页面中虽然不渲染此条数据,但依然占据位置
  2. 监听页面滚动事件,更改部分数据源
    • 设置监听事件
      window.removeEventListener('scroll', handleScroll);
      (注意:若使用前端框架或组件库,设置监听事件的方式可以不同,依据实际的事件监听添加方式设置监听事件)
    • 在监听事件 handleScroll 中更新部分数据源

      根据滚动的位置,更新部分数据源中的值

      1. 通过事件对象的scrollTop属性获取当前滚动的位置
      2. 假设每条数据都是同样的高度,获取到一条的高度 itemHeight,则用scrollTop/itemHeight 获取到当前可视区域滚动的位置第index
      3. 遍历原始数据源,若当前数据在 index-50 ~ index+50 之间,则将此条数据加入到部分数据源中,否则,将{}加入到部分数据源中占位
  3. 将部分数据源遍历渲染到页面上

实战中虚拟列表的问题及相应解决方案

页面滑动过快可能会有白屏问题,在此仅提供一个思路:可使用骨架屏的方案处理

相关文章:

前端列表数据太多导致页面卡顿就这么处理

前端列表数据太多页面卡顿就这么处理 实际场景什么是虚拟列表虚拟列表实现原理实战中虚拟列表的问题及相应解决方案 实际场景 首先看以下两个实际场景: 场景一:有一个数据列表,数据量非常大且每一个数据项都有几十列甚至更多,且后…...

机器学习_神经网络_深度学习

【神经网络——最易懂最清晰的一篇文章 - CSDN App】https://blog.csdn.net/illikang/article/details/82019945?type=blog&rId=82019945&refer=APP&source=weixin_45387165 参考以上资料,可对神经网络有初步了解。接下来可参考书籍等投身实际项目中使用。 书…...

MT6765/MT6762(R/D/M)/MT6761(MT8766)安卓核心板参数比较_MTK联发科4G智能模块

联发科Helio P35 MT6765安卓核心板 MediaTek Helio P35 MT6765是智能手机的主流ARM SoC,于2018年末推出。它在两个集群中集成了8个ARM Cortex-A53内核(big.LITTLE)。四个性能内核的频率高达2.3GHz。集成显卡为PowerVR GE8320,频率…...

TikTok五分钟开户快速步骤流程!

1、注册您的账户 首先,访问TikTok广告管理器的注册页面(https://ads.tiktok.com/i18n/signup/)以创建账户。您可以选择使用电子邮件或手机号码进行注册。输入您的电子邮件和密码后,您需要同意TikTok的广告条款,然后点击…...

BFS 解决拓扑排序 , 课程表 , 课程表 II , 火星词典

文章目录 拓扑排序简介1.有向无环图(DAG图)2.AOV网:顶点活动图3.拓扑排序4.实现拓扑排序 207. 课程表210. 课程表 IILCR 114. 火星词典 拓扑排序简介 1.有向无环图(DAG图) 像这样只能从一个点到另一个点有方向的图&a…...

web安全攻防渗透测试实战指南_web安全攻防渗透测试实战指南,零基础入门到精通,收藏这一篇就够了

1. Nmap的基本 Nmap ip 6 ip Nmap -A 开启操作系统识别和版本识别功能 – T(0-6档) 设置扫描的速度 一般设置T4 过快容易被发现 -v 显示信息的级别,-vv显示更详细的信息 192.168.1.1/24 扫描C段 192.168.11 -254 上 nmap -A -T4 -v -i…...

大模型如何赋能智慧城市新发展?

国家数据局近期发布的《数字中国发展报告(2023)》显示,我国数据要素市场化改革步伐进一步加快,数字经济规模持续壮大,数字技术应用场景不断拓展。这一成就的背后是数字技术广泛应用,数字技术不仅影响着老百…...

随记——机器学习

前言 本来有个500块钱的单子,用机器学习做一个不知道什么鸟的识别,正好有数据集,跑个小项目,过一下机器学习图像识别的流程,用很短的时间记录下来..... 一、数据预处理 将数据集分为训练集和测试集,直接…...

【在Linux世界中追寻伟大的One Piece】进程间通信

目录 1 -> 进程间通信介绍 1.1 -> 进程间通信目的 1.2 -> 进程间通信发展 1.3 -> 进程间通信分类 1.3.1 -> 管道 1.3.2 -> System V IPC 1.3.3 -> POSIX IPC 2 -> 管道 2.1 -> 什么是管道 2.2 -> 匿名管道 2.3 -> 实例代码 2.4 -…...

多路复用IO

一。进程处理多路IO请求 在没有多路复用IO之前,对于多路IO请求,一般只有阻塞与非阻塞IO两种方式 1.1 阻塞IO 需要结合多进程/多线程,每个进程/线程处理一路IO 缺点:客户端越多,需要创建的进程/线程越多&#xff0c…...

C++ prime plus-7-編程練習

1&#xff0c; #include <iostream>// 函数声明 double harmonicMean(double x, double y);int main() {double x, y, result;while (true) {std::cout << "请输入两个数&#xff08;其中一个为0时结束&#xff09;: ";std::cin >> x >> y;…...

计算1 / 1 - 1 / 2 + 1 / 3 - 1 / 4 + 1 / 5 …… + 1 / 99 - 1 / 100 的值,打印出结果

我们写这道题的时候需要俩变量接受&#xff0c;一个总数一个分母&#xff0c;我们发现分母变化是有规律的从1~100循环。 #include<stdio.h> int main() {int i 0;int tag 1;double sum 0.0;for (i 1; i < 101; i){if (i % 2 0){sum sum - 1.0 / i;}else{sum s…...

Linux本地服务器搭建开源监控服务Uptime Kuma与远程监控实战教程

文章目录 前言**主要功能**一、前期准备本教程环境为&#xff1a;Centos7&#xff0c;可以跑Docker的系统都可以使用本教程安装。本教程使用Docker部署服务&#xff0c;如何安装Docker详见&#xff1a; 二、Docker部署Uptime Kuma三、实现公网查看网站监控四、使用固定公网地址…...

JS 历史简介

目录 1. JS 历史简介 2. JS 技术特征 1. JS 历史简介 举例&#xff1a;在提交用户的注册信息的时候&#xff0c;为避免注册出现错误后重新填写信息&#xff0c;可以在写完一栏信息后进行校验&#xff0c;并提示是否出现错误&#xff0c;这样会大大提高用户提交的成功率&…...

爬虫逆向学习(七):补环境动态生成某数四代后缀MmEwMD

声明&#xff1a;本篇文章内容是整理并分享在学习网上各位大佬的优秀知识后的实战与踩坑记录 前言 这篇文章主要是研究如何动态生成后缀参数MmEwMD的&#xff0c;它是在文章爬虫逆向学习(六)&#xff1a;补环境过某数四代的基础上进行研究的&#xff0c;代码也是在它基础上增…...

光伏电站并网验收需要注意什么细节

一、设备质量及安装验收 光伏组件&#xff1a;检查光伏组件的外观是否完好无损&#xff0c;无明显的缺陷和破损&#xff0c;表面是否清洁无污染。同时&#xff0c;需要验证光伏组件的型号、参数是否与设备台账资料一致。 逆变器&#xff1a;确认逆变器具备防雷、防尘、防潮等…...

页面禁用鼠标右键属于反爬虫措施吗 ?

是的&#xff0c;禁用鼠标右键通常被视为一种反爬虫&#xff08;anti-scraping&#xff09;措施。网站开发者常常采用这种技术来防止用户通过右键菜单复制文本、图像或其他内容&#xff0c;特别是在内容保护和数据安全方面。以下是禁用鼠标右键的一些背景和目的&#xff1a; 1…...

视频理解大模型最新进展

文章目录 Video-LLaMAVision-Language BranchAudio-Language Branch Video-ChatGPTMiniGPT4-videoCogVLM2-Video&#xff08;1&#xff09;Pre-training&#xff08;2&#xff09;Post-training Qwen2-VLMA-LMMChat-UniVi大模型对比 Video-LLaMA 2023&#xff1a;阿里达摩院的…...

cocos creator 使用 protobuf 的步骤与注意事项

移除可能曾安装过的protobuf // 移除全局 npm remove -g protobufjs npm remove -g protobufjs-cli npm remove -g pbjs // 移除项目中的 npm remove --save protobufjs npm remove --save protobufjs-cli npm remove --save pbjs全局安装 npm i -g protobufjs //或者 cnpm …...

mac访达查找文件目录

mac访达查找文件目录 在Mac上使用访达&#xff08;Finder&#xff09;查找文件或目录的方法如下&#xff1a; 打开访达。 在访达窗口的侧边栏中&#xff0c;选择“ Go to Folder”&#xff08;转到文件夹&#xff09;选项&#xff0c;或者使用快捷键ShiftCommandG打开一个对…...

5个实用技巧:让你的微信自动化工具真正发挥价值

5个实用技巧&#xff1a;让你的微信自动化工具真正发挥价值 【免费下载链接】wxauto Windows版本微信客户端&#xff08;非网页版&#xff09;自动化&#xff0c;可实现简单的发送、接收微信消息&#xff0c;简单微信机器人 项目地址: https://gitcode.com/gh_mirrors/wx/wxa…...

失真度测量仪校准 失真度测量仪校准检定装置应用方案 失真度仪校准器 失真度仪检定装置

在电子测量、计量检定、设备运维及科研生产等领域&#xff0c;失真度仪是检测信号纯净度的核心仪器&#xff0c;其测量精度直接决定产品质量管控、设备运维可靠性及科研数据准确性。但实际应用中&#xff0c;传统校准设备普遍存在精度不足、操作繁琐、场景适配性差、数据管理不…...

ComfyUI-Easy-Use:GPU资源优化与深度学习推理效能提升实践

ComfyUI-Easy-Use&#xff1a;GPU资源优化与深度学习推理效能提升实践 【免费下载链接】ComfyUI-Easy-Use In order to make it easier to use the ComfyUI, I have made some optimizations and integrations to some commonly used nodes. 项目地址: https://gitcode.com/g…...

揭秘USDT混币器:从智能合约代码到浏览器控制台,一次匿名转账的完整技术栈解析

揭秘USDT混币器&#xff1a;从智能合约代码到浏览器控制台的技术全景 在区块链世界中&#xff0c;隐私保护与交易透明性似乎是一对永恒的矛盾。当每一笔USDT转账都能被链上浏览器追踪到资金流向时&#xff0c;一种名为"混币器"的技术方案正在用密码学重新定义匿名边界…...

5大实战技巧让你精通FDS火灾动力学模拟技术

5大实战技巧让你精通FDS火灾动力学模拟技术 【免费下载链接】fds Fire Dynamics Simulator 项目地址: https://gitcode.com/gh_mirrors/fd/fds 当一场突如其来的火灾发生时&#xff0c;传统的消防设计往往只能依靠经验估算&#xff0c;而FDS&#xff08;Fire Dynamics S…...

Anything-v5模型微调启示:Pixel Fashion Atelier对动漫风格像素化表达的重构

Anything-v5模型微调启示&#xff1a;Pixel Fashion Atelier对动漫风格像素化表达的重构 1. 项目背景与设计理念 Pixel Fashion Atelier是一个创新的图像生成工作站&#xff0c;它巧妙融合了Stable Diffusion的强大生成能力与Anything-v5模型对动漫风格的精准把控。这个项目最…...

人脸识别OOD模型在医疗领域的应用探索

人脸识别OOD模型在医疗领域的应用探索 1. 引言 在医院里&#xff0c;每天都有成千上万的患者需要身份确认、用药核对和病情监测。传统的医疗身份验证方式如手环、身份证件等存在被冒用、丢失或信息错误的风险。而医护人员在繁忙的工作中&#xff0c;也可能因为疲劳或疏忽而错…...

MOOTDX:Python通达信数据接口解决方案

MOOTDX&#xff1a;Python通达信数据接口解决方案 【免费下载链接】mootdx 通达信数据读取的一个简便使用封装 项目地址: https://gitcode.com/GitHub_Trending/mo/mootdx 在量化投资领域&#xff0c;数据获取与处理始终是从业者面临的核心挑战。个人投资者常常困于复杂…...

Cadence 617实战:手把手教你搞定电流镜负载差分放大器的仿真与优化

Cadence 617实战&#xff1a;手把手教你搞定电流镜负载差分放大器的仿真与优化 在模拟集成电路设计中&#xff0c;电流镜负载差分放大器是一个经典而重要的电路结构。它不仅出现在各类运算放大器的输入级&#xff0c;也是理解模拟电路设计原理的绝佳案例。本文将带你从工具实操…...

遇到复杂车线桥耦合分析总被建模效率卡脖子?试试Simpack+Abaqus/ANSYS这套组合拳,咱们直接上干货聊聊那些提效黑科技

simpack abaqus ansys车线桥耦合高效建模分析工具 1.快速生成非线性柔性轨节点处mark 2.桥梁纵向轨底处的对应的mark及坐标 3.快速建立力元并设置preload方向 4.免安装运行环境点击exe输入 5.基于ansys或者abaqus和simpack联合仿真的5跨、3跨简支梁车线桥耦合分析实例轨节点标记…...