• Vue内置组件之KeepAlive原理


    前言

    最近看 Vue 相关的知识点,看到 KeepAlive 组件时比较好奇它是怎么做到组件间切换时不重新渲染的,于是便稍微深入的了解了一下

    如果你也有兴趣想要了解一下具体内部怎么实现的或者说有一定的了解但是不够熟悉,那么正好你也可以一起巩固下

    Tips: 这样面试的时候你就可以大声的问别人这个知识点了🤔。

    KeepAlive 是什么

    是一个内置组件,它的功能是在多个组件间动态切换缓存被移除的组件实例。

    KeepAlive 功能

    KeepAlive 一词借鉴于 HTTP 协议,在 HTTP 协议里面 KeepAlive 又称持久连接,作用是允许多个请求/响应共用同一个 HTTP 连接,解决了频繁的销毁和创建 HTTP 连接带来的额外性能开销。而同理 Vue 里的 KeepAlive 组件也是为了避免一个组件被频繁的销毁/重建,避免了性能上的开销。

    // App.vue
    
    
    
    toggle
    • 1
    • 2
    • 3
    • 4

    上述代码可以看到,如果我们频繁点击 toggle 时会频繁的渲染 Test/HelloWorld 组件,当用户频繁的点击时 Test 组件需要频繁的销毁/渲染,这就造成很大的渲染性能损失。

    所以为了解决这种性能开销,你需要知道是时候使用 KeepAlive 组件。

    
      
    
    
    toggle
    • 1
    • 2
    • 3
    • 4

    在这里插入图片描述

    可以看这个录屏,在首次加载后再次频繁的切换并没有重新销毁与挂载,而仅仅是将组件进行了失活(而不是销毁),渲染时只需要重新激活就可以,而不需重新挂载,如果要渲染的组件很大,那就能有不错的性能优化

    想要体验的话可以去看看这个例子🌰官方demo,其中数据会被缓存这个也需要在开发使用中去注意到的

    如何实现

    实现原理其实很简单,其实就是缓存管理和特定的销毁和渲染逻辑,使得它不同于其他组件。

    KeepAlive 组件在卸载组件时并不能真的将其卸载,而是将其放到一个隐藏的容器里面当被激活时再从隐藏的容器中拿出来挂载到真正的 dom 上就行,这也就对应了 KeepAlive 的两个独特的生命周期activateddeactivated

    [外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-ngeUGtXD-1668172656293)(https://p9-juejin.byteimg.com/tos-cn-i-k3u1fbpfcp/74acec749d6b45fc9d1e3d37dd895e28~tplv-k3u1fbpfcp-watermark.image?)]

    先来简单了解下组件的挂载过程

  • 相关阅读:
    java计算机毕业设计ssm企业日常事务管理系统sl5xl(附源码、数据库)
    C++ Qt QModbusClient 的使用
    Python 小贴士(3)
    微服务TraceId设计(SpringCloud OpenFeign)
    设计模式-原型模式
    设计模式-享元模式
    身份和访问管理IAM能力之RADIUS认证
    无损以太网的ROCE革命,队列的缓存空间优化分析
    hosts.allow限制可通过SSH登录到服务器的IP
    Kibana Query Language (KQL)
  • 原文地址:https://blog.csdn.net/cyg_l02/article/details/127813373