一个超冷门的 Vue3 内置组件,帮我优化了66%的性能!

开发 前端
最近项目中有一个页面,是之前的老页面,页面中的内容其实就是一个 Tabs 组件,有三个 Tab,分别展示不同的内容,但是也有共同内容,那就是共同都有一个一个报表组件

前言

大家好,我是林三心,用最通俗易懂的话讲最难的知识点是我的座右铭,基础是进阶的前提是我的初心~

背景

最近项目中有一个页面,是之前的老页面,页面中的内容其实就是一个 Tabs 组件,有三个 Tab,分别展示不同的内容,但是也有共同内容,那就是共同都有一个一个报表组件

图片图片

下面是大致的代码展示如下,为了方便大家阅读吗,我把代码简化了

图片图片

Chart.vue中会进行大量的请求,这里我就直接简单模拟一下了

图片图片

但是当我阅读到这一段旧代码时,我就觉得不太妙,这代码这么写,显然是没有考虑到性能问题,我们可以切换 Tab1 -> Tab2 -> Tab3 ,会发现 Chart.vue 请求了三次!!!

图片图片

但是其实只需要请求一次就够了,因为其实都是一样的数据、一样的组件,并且 Chart.vue 内部的请求其实是很多个的,这样就大大浪费了浏览器资源

改进?

其实很多人第一时间就是想到了,我们可以只请求一次,然后让这三个 Chart 共用同一份数据,这样做就能保证只请求一次了

确实,这样做大大提升了性能,大致的代码如下,也就是把请求放在 Index 中去做,然后把数据传给三个 Chart

图片图片

Chart 中只需要接收,并渲染即可

图片图片

现在切换 Tab1 -> Tab2 -> Tab3,发现确实只请求了一次了,这对于这个页面,简直是很大的提升!

图片图片

结束了吗?

其实 Chart 内部拿到数据之后,会拿着数据去渲染很多的东西(这里我简化了而已,其实很多的)。

刚刚我们只是保证了请求是一次,但是我们并没有保证渲染是一次哦~我们可以给 Chart 的 onMounted 中加个打印

图片图片

切换 Tab1 -> Tab2 -> Tab3,可以看到总共渲染了三次,这其实也降低了页面的性能,理想是只渲染一次即可

图片图片

巧妙使用 Teleport

也就是,我需要做到只渲染一次 Chart,但是需要渲染到不同的三个 Tab 中去~

那就只能是动态地去渲染了,根据选择不同的 Tab,去决定 Chart 渲染到哪个 Tab 下了

这时候我就想到了 Teleport 了,这是一个 Vue3 提供的 全局组件,类似于一个传送门,能把一个 DOM 节点渲染到另一个 DOM 节点上

改进后的代码如下

图片图片

现在切换 Tab1 -> Tab2 -> Tab3,可以看到

  • 请求只一次
  • 渲染只一次

真是太妙了!!!

图片 图片

责任编辑:武晓燕 来源: 前端之神
相关推荐

2022-09-20 11:00:14

Vue3滚动组件

2024-07-30 08:59:22

2024-01-16 12:46:00

Vue3API开发

2020-11-12 08:32:14

Vue3模板优化

2022-07-18 10:43:12

项目TienChinJava

2024-08-12 08:33:05

2020-12-01 08:34:31

Vue3组件实践

2024-01-25 09:09:00

fsp帧数游戏

2024-01-22 13:15:00

2011-05-03 10:17:25

CSS

2021-01-15 05:16:37

Vue3开源代码量

2024-08-12 09:28:02

Vue3项目技巧

2024-08-13 09:26:07

2021-05-18 07:51:37

Suspense组件Vue3

2023-04-02 10:06:24

组件vue3sign2.

2022-08-09 10:00:57

ViteTypeScripVue3

2023-04-27 11:07:24

Setup语法糖Vue3

2021-05-06 07:40:56

Vue3 Vue2 组件

2023-04-28 08:35:22

Vue 3Vue 2

2020-08-24 08:34:03

命令性能优化
点赞
收藏

51CTO技术栈公众号