当前位置:首页 > 科技  > 软件

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

来源: 责编: 时间:2024-02-29 14:41:15 223观看
导读前言大家好,我是林三心,用最通俗易懂的话讲最难的知识点是我的座右铭,基础是进阶的前提是我的初心~背景最近项目中有一个页面,是之前的老页面,页面中的内容其实就是一个 Tabs 组件,有三个 Tab,分别展示不同的内容,但是也有共

前言

大家好,我是林三心,用最通俗易懂的话讲最难的知识点是我的座右铭,基础是进阶的前提是我的初心~jXB28资讯网——每日最新资讯28at.com

背景

最近项目中有一个页面,是之前的老页面,页面中的内容其实就是一个 Tabs 组件,有三个 Tab,分别展示不同的内容,但是也有共同内容,那就是共同都有一个一个报表组件jXB28资讯网——每日最新资讯28at.com

图片图片jXB28资讯网——每日最新资讯28at.com

下面是大致的代码展示如下,为了方便大家阅读吗,我把代码简化了jXB28资讯网——每日最新资讯28at.com

图片图片jXB28资讯网——每日最新资讯28at.com

Chart.vue中会进行大量的请求,这里我就直接简单模拟一下了jXB28资讯网——每日最新资讯28at.com

图片图片jXB28资讯网——每日最新资讯28at.com

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

图片图片jXB28资讯网——每日最新资讯28at.com

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

改进?

其实很多人第一时间就是想到了,我们可以只请求一次,然后让这三个 Chart 共用同一份数据,这样做就能保证只请求一次了jXB28资讯网——每日最新资讯28at.com

确实,这样做大大提升了性能,大致的代码如下,也就是把请求放在 Index 中去做,然后把数据传给三个 ChartjXB28资讯网——每日最新资讯28at.com

图片图片jXB28资讯网——每日最新资讯28at.com

Chart 中只需要接收,并渲染即可jXB28资讯网——每日最新资讯28at.com

图片图片jXB28资讯网——每日最新资讯28at.com

现在切换 Tab1 -> Tab2 -> Tab3,发现确实只请求了一次了,这对于这个页面,简直是很大的提升!jXB28资讯网——每日最新资讯28at.com

图片图片jXB28资讯网——每日最新资讯28at.com

结束了吗?

其实 Chart 内部拿到数据之后,会拿着数据去渲染很多的东西(这里我简化了而已,其实很多的)。jXB28资讯网——每日最新资讯28at.com

刚刚我们只是保证了请求是一次,但是我们并没有保证渲染是一次哦~我们可以给 Chart 的 onMounted 中加个打印jXB28资讯网——每日最新资讯28at.com

图片图片jXB28资讯网——每日最新资讯28at.com

切换 Tab1 -> Tab2 -> Tab3,可以看到总共渲染了三次,这其实也降低了页面的性能,理想是只渲染一次即可jXB28资讯网——每日最新资讯28at.com

图片图片jXB28资讯网——每日最新资讯28at.com

巧妙使用 Teleport

也就是,我需要做到只渲染一次 Chart,但是需要渲染到不同的三个 Tab 中去~jXB28资讯网——每日最新资讯28at.com

那就只能是动态地去渲染了,根据选择不同的 Tab,去决定 Chart 渲染到哪个 Tab 下了jXB28资讯网——每日最新资讯28at.com

这时候我就想到了 Teleport 了,这是一个 Vue3 提供的 全局组件,类似于一个传送门,能把一个 DOM 节点渲染到另一个 DOM 节点上jXB28资讯网——每日最新资讯28at.com

改进后的代码如下jXB28资讯网——每日最新资讯28at.com

图片图片jXB28资讯网——每日最新资讯28at.com

现在切换 Tab1 -> Tab2 -> Tab3,可以看到jXB28资讯网——每日最新资讯28at.com

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

真是太妙了!!!jXB28资讯网——每日最新资讯28at.com

图片 图片 jXB28资讯网——每日最新资讯28at.com

本文链接:http://www.28at.com/showinfo-26-75321-0.html一个超冷门的 Vue3 内置组件,帮我优化了66%的性能!

声明:本网页内容旨在传播知识,若有侵权等问题请及时与本网联系,我们将在第一时间删除处理。邮件:2376512515@qq.com

上一篇: Java的函数式接口编程示例

下一篇: 是否还记得SpringMVC中的@MatrixVariable注解?

标签:
  • 热门焦点
  • 2023年Q2用户偏好榜:12+256G版本成新主流

    3月份的性能榜、性价比榜和好评榜之后,就要轮到2023年的第二季度偏好榜了,上半年的新机潮已经过去,最明显的肯定就是大内存和存储的机型了,另外部分中端机也取消了屏幕塑料支架
  • Python异步IO编程的进程/线程通信实现

    这篇文章再讲3种方式,同时讲4中进程间通信的方式一、 Python 中线程间通信的实现方式共享变量共享变量是多个线程可以共同访问的变量。在Python中,可以使用threading模块中的L
  • 每天一道面试题-CPU伪共享

    前言:了不起:又到了每天一到面试题的时候了!学弟,最近学习的怎么样啊 了不起学弟:最近学习的还不错,每天都在学习,每天都在进步! 了不起:那你最近学习的什么呢? 了不起学弟:最近在学习C
  • 零售大模型“干中学”,攀爬数字化珠峰

    文/侯煜编辑/cc来源/华尔街科技眼对于绝大多数登山爱好者而言,攀爬珠穆朗玛峰可谓终极目标。攀登珠峰的商业路线有两条,一是尼泊尔境内的南坡路线,一是中国境内的北坡路线。相
  • 一条抖音4亿人围观 ! 这家MCN比无忧传媒还野

    作者:Hiu 来源:互联网品牌官01 擦边少女空降热搜,幕后推手曝光被网友誉为“纯欲天花板”的女网红井川里予,近期因为一组哥特风照片登上热搜,引发了一场互联网世界关于
  • iQOO Neo8系列今日官宣:首发天玑9200+ 全球安卓最强芯!

    在昨日举行的的联发科新一代旗舰芯片天玑9200+的发布会上,iQOO官方也正式宣布,全新的iQOO Neo8系列新品将全球首发搭载这款当前性能最强大的移动平台
  • 与兆芯合作 联想推出全新旗舰版笔记本电脑开天N7系列

    联想与兆芯合作推出全新联想旗舰版笔记本电脑开天 N7系列。这个系列采用兆芯KX-6640MA处理器平台,KX-6640MA 处理器是采用了陆家嘴架构,16nm 工艺,4 核 4 线
  • 英特尔Xe HPG游戏显卡:拥有512EU,单风扇版本

    据10 月 30 日外媒 TheVerge 消息报道,英特尔 Xe HPG Arc Alchemist 的正面实被曝光,不仅拥有 512 EU 版显卡,还拥有 128EU 的单风扇版本。另外,这款显卡 PCB
  • 中关村论坛11月25日开幕,15位诺奖级大咖将发表演讲

    11月18日,记者从2022中关村论坛新闻发布会上获悉,中关村论坛将于11月25至30日在京举行。本届中关村论坛由科学技术部、国家发展改革委、工业和信息化部、国务
Top