页面性能优化

优化点 解决方案 效果
1. ### 双向绑定数量过多 竞对设置单元格内部涉及双向绑定的输入组件过多,线上页面最多有88个 该和抽屉中的编辑表格一样的组件,共计**930+个(按每行最少6个来计算的)**双向绑定的组件,严重拖累页面性能。 数据计算依据:88 = 竞对信息单元格数,930 = 155(编辑表格行数)*6(每行最低的双向绑定组件数) 问题截图 将竞对设置的编辑表格 改为纯文本展示表格全局仅维护一个编辑表格,点击对应单元格的编辑按钮后,显示抽屉,将目标单元格数据带入编辑表格进行编辑操作,编辑完成后将修改后的数据同步到目标单元格对应的数据对象中。 通用的编辑表格组件数量由88个 缩减到1个 ,双向绑定组件由930+ 个缩减到20个以内(线上数据每个编辑表格大概2-3行)
2. 高并发重复请求​ 这是在子组件请求接口,没有做接口缓存,导致调用N次请求。 缓存后,不切换城市只请求一次。
3. 树型选择器渲染函数时间复杂度高 线上场景组织节点数为5377个 ,当选择父级节点时,树型选择器renderTag方法使用了**O(n2)**的查找父节点遍历方法。 该renderTag方法在初始化、点击选择框、选择值、选择框失焦等多个事件中都会触发。 问题截图: 使用Map进行缓存,将函数时间复杂度降为O(n) javascript // 优化前:filter+some 二层嵌套循环 时间复杂度为O(n2) const allTagList = data.filter((item) => { // 如果 item 有父节点,检查父节点是否选中 if (item.parentId) { // 查找时间为O(n) return !data.some((dataItem) => dataItem.id === item.parentId); } // 如果 item 没有父节点,直接选中 return true; }); // 优化后:Map直接读数时间复杂度为O(n) const allTagList = data.filter((item) => { // 如果 item 有父节点,检查父节点是否选中 if (item.parentId) { // 使用 Map 的 has 方法,时间复杂度 O(1) return !selectedIdMap.has(item.parentId); } // 如果 item 没有父节点,直接选中 return true; });
4. 写法优化。 使用Set (n1)查找 避免模版直传方法渲染,替换为计算属性
相关推荐
JohnnyDeng944 小时前
【Android】Android 包体积优化:R8/ProGuard 深度配置全攻略
android·性能优化·kotlin·jetpack
Zyed7 小时前
[STM32]Day15读写FLASH+读取ID
前端·stm32·性能优化
深蓝电商API11 小时前
无头浏览器性能优化:内存占用从2GB降到200MB
爬虫·性能优化
cfm_291412 小时前
JVM垃圾收集算法与收集器深度解析
jvm·测试工具·算法·性能优化
1892280486114 小时前
NV114固态MT29F16T08EWLEHD6-MES:E
人工智能·算法·缓存·性能优化
超哥--15 小时前
B站视频内容智能分析系统(十):踩坑记录与性能优化
性能优化·音视频·ai编程
Gong-Yu15 小时前
MySQL数据库运维——性能优化进阶2️⃣
运维·数据库·mysql·性能优化
hai31524754315 小时前
九章编程法 · 字典引擎【0/1拓扑步进 · 矩阵压缩·终极封版】
人工智能·数学建模·性能优化·动态规划·代码复审·傅立叶分析·极限编程
爱喝水的鱼丶1 天前
SAP-ABAP:SAP视图开发入门:四类标准视图的适用场景与创建步骤详解
服务器·数据库·性能优化·sap·abap
ViavaCos1 天前
AI 帮我写代码,我帮 AI 踩坑:Vue 大数据表格优化全记录
前端·性能优化