el-table 可编辑表格大数据渲染性能优化

2024-01-12 02:36

本文主要是介绍el-table 可编辑表格大数据渲染性能优化,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

背景与分析

可编辑表格:是指表格单元格是一个form表单元素,或者有可能会变成表单元素。
1、不可分页的表格,大数据渲染
当数据量足够大时,比如说1000条数据,页面渲染就会卡死,需要卡5s到10s,才能将数据渲染到页面,完全渲染出来后,页面的其他操作也是非卡顿,有明显的延迟感。
2、分页表格,用户大量新增数据,或复制、导入大量的数据
因前端分页,初始化时,以及完全渲染之后,页面都很流畅;但是当允许用户新增数据时,限制用户的新增数量也就不会有上述的问题,当不限制时,在完全渲染出来后,页面其他操作也会有明显的延迟感。

现需要对初次渲染卡顿,完全渲染卡顿两个角度,进行性能优化。

技术方案

0、分页表格 —— 限制新增的行数,每次只能新增10行20行的

开发不定需求,需求能肯定最好,但是需求可能会从批量操作,导入等角度考虑,不要进行分页,那我们就只能进行性能优化

1、比较多的解决方案是虚拟加载 —— el-table-virtual-scroll

如果是单行编辑保存,或者是不可编辑的话,也不失为一个好的解决方案,
但是如果是编辑所有行之后,统一保存,可编辑表格,有必填项,运行了form的validate,就不能正常的进行表单校验,因为滚动出可视区域之后,form-item即被销毁,开发只能手写校验方法,且不同的业务功能,会有不同的校验规则,完全共用不了,增加组件的使用难度

2、懒加载 —— 滚动加载

当表格内容大于一定数量后,肯定是可以滚动的,滚动加载,表格滚动条的展示会有问题,需要使用虚拟滚动条,
滚动加载,比如先渲染20条数据,当用户滚动后,再渲染后面20条数据。初始化时,渲染速度很快,但是当用户滚动到一定程度,整个页面会渲染出大量的DOM,导致页面有明显的延迟感

3、点击加载 —— 点击行的时候,去加载行的form表单元素

点击加载,当可编辑时,该行允许用户编辑时,点击后,渲染该行的form表单,当用户点击其他行时,渲染其他行的form表单,销毁当前行的form表单,以控制页面展示dom的数量。但是会有必填字段没填,校验失败的字段,也销毁了,导致后面校验异常,更定位不到校验失败的字段。当然我们可以在校验失败时,也渲染form表单就不会有这个问题。
但是当数据很大时,依旧初次渲染卡顿,完全渲染卡顿,只能是属于提升性能的一个小手段吧

4、任务切片 —— 将初始化大数据渲染,这个大任务进行切片

初始化时渲染所有的数据时,这一整个任务耗时严重,我们把这个任务拆分,渲染20条数据,500ms后渲染后面20条,直至所有数据渲染完毕,可以解决初始化渲染卡顿的问题,但是会有完全渲染后卡顿的问题

5、动态渲染 —— 让浏览器不渲染非可视区的内容

content-visibility: auto,跳过屏幕外的内容渲染,解决完全渲染后卡顿的问题

分析利弊

各个方案均有利弊,没有完美的解决方案,需要具体的问题具体分析;
多个技术聚合使用,采长补短,达到符合自身的需求;
现说一下我的优化套餐
点击加载 + 任务切片 + 动态渲染,只提交被修改的数据,只校验被修改的数据保存校验时,可以正常校验,并定位到校验失败的字段
缺点:

  1. 勾选状态异常,切片会导致数据更新,之前的选中状态会丢失;
  2. 全选,点击勾选列的标题头上的全选,异常,不能全部勾选,后面异常也不能反选;
  3. 表格tr上的content-visibility不生效

2024/01/08持续维护中…

方案落地

详细代码

这篇关于el-table 可编辑表格大数据渲染性能优化的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/596530

相关文章

Springboot中分析SQL性能的两种方式详解

《Springboot中分析SQL性能的两种方式详解》文章介绍了SQL性能分析的两种方式:MyBatis-Plus性能分析插件和p6spy框架,MyBatis-Plus插件配置简单,适用于开发和测试环... 目录SQL性能分析的两种方式:功能介绍实现方式:实现步骤:SQL性能分析的两种方式:功能介绍记录

Deepseek使用指南与提问优化策略方式

《Deepseek使用指南与提问优化策略方式》本文介绍了DeepSeek语义搜索引擎的核心功能、集成方法及优化提问策略,通过自然语言处理和机器学习提供精准搜索结果,适用于智能客服、知识库检索等领域... 目录序言1. DeepSeek 概述2. DeepSeek 的集成与使用2.1 DeepSeek API

Redis的数据过期策略和数据淘汰策略

《Redis的数据过期策略和数据淘汰策略》本文主要介绍了Redis的数据过期策略和数据淘汰策略,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一... 目录一、数据过期策略1、惰性删除2、定期删除二、数据淘汰策略1、数据淘汰策略概念2、8种数据淘汰策略

轻松上手MYSQL之JSON函数实现高效数据查询与操作

《轻松上手MYSQL之JSON函数实现高效数据查询与操作》:本文主要介绍轻松上手MYSQL之JSON函数实现高效数据查询与操作的相关资料,MySQL提供了多个JSON函数,用于处理和查询JSON数... 目录一、jsON_EXTRACT 提取指定数据二、JSON_UNQUOTE 取消双引号三、JSON_KE

Python给Excel写入数据的四种方法小结

《Python给Excel写入数据的四种方法小结》本文主要介绍了Python给Excel写入数据的四种方法小结,包含openpyxl库、xlsxwriter库、pandas库和win32com库,具有... 目录1. 使用 openpyxl 库2. 使用 xlsxwriter 库3. 使用 pandas 库

Tomcat高效部署与性能优化方式

《Tomcat高效部署与性能优化方式》本文介绍了如何高效部署Tomcat并进行性能优化,以确保Web应用的稳定运行和高效响应,高效部署包括环境准备、安装Tomcat、配置Tomcat、部署应用和启动T... 目录Tomcat高效部署与性能优化一、引言二、Tomcat高效部署三、Tomcat性能优化总结Tom

SpringBoot定制JSON响应数据的实现

《SpringBoot定制JSON响应数据的实现》本文主要介绍了SpringBoot定制JSON响应数据的实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们... 目录前言一、如何使用@jsonView这个注解?二、应用场景三、实战案例注解方式编程方式总结 前言

使用Python在Excel中创建和取消数据分组

《使用Python在Excel中创建和取消数据分组》Excel中的分组是一种通过添加层级结构将相邻行或列组织在一起的功能,当分组完成后,用户可以通过折叠或展开数据组来简化数据视图,这篇博客将介绍如何使... 目录引言使用工具python在Excel中创建行和列分组Python在Excel中创建嵌套分组Pyt

在Rust中要用Struct和Enum组织数据的原因解析

《在Rust中要用Struct和Enum组织数据的原因解析》在Rust中,Struct和Enum是组织数据的核心工具,Struct用于将相关字段封装为单一实体,便于管理和扩展,Enum用于明确定义所有... 目录为什么在Rust中要用Struct和Enum组织数据?一、使用struct组织数据:将相关字段绑

在Mysql环境下对数据进行增删改查的操作方法

《在Mysql环境下对数据进行增删改查的操作方法》本文介绍了在MySQL环境下对数据进行增删改查的基本操作,包括插入数据、修改数据、删除数据、数据查询(基本查询、连接查询、聚合函数查询、子查询)等,并... 目录一、插入数据:二、修改数据:三、删除数据:1、delete from 表名;2、truncate