前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >vue3中的KeepAlive原理到底是什么(一)

vue3中的KeepAlive原理到底是什么(一)

作者头像
zhouzhouya
发布2023-10-26 17:31:08
1790
发布2023-10-26 17:31:08
举报
文章被收录于专栏:一名前端开发一名前端开发

KeepAlive是什么

KeepAlive借鉴http协议,在http中KeepAlive是避免链接频繁的销毁和创建,那vue中的KeepAlive是什么呢,它的作用是避免组件被频繁的销毁和创建。

KeepAlive组件的实现需要渲染器的支持

为什么KeepAlive组件的实现需要渲染器的支持呢,是因为KeepAlive组件在卸载时,是将KeepAlive从一个容器搬到另外一个隐藏的容器,实现假卸载。当被搬运的组件需要再次被挂载的时候,是把其从隐藏的容器中搬到原容器。这个过程对应组件的生命周期是activated和的deactivated。

缓存机制

KeepAlive 组件是通过LRU算法来实现缓存机制。(暂不讲解下一篇文章讲述)

缓存实现

代码语言:javascript
复制
const KeepAliveImpl = {
  __isKeepAlive: true,
  inheritRef: true,
  props: {
    include: [String, RegExp, Array],
    exclude: [String, RegExp, Array],
    max: [String, Number]
  },
  setup(props: KeepAliveProps, { slots }: SetupContext){

    // 省略其他代码...

    return()=>{
      if (!slots.default) {
        return null
      }
      const children = slots.default()
      let vnode = children[0]  
      if (children.length > 1) {
        current = null
        return children
      } else if (
        !isVNode(vnode) ||
        !(vnode.shapeFlag & ShapeFlags.STATEFUL_COMPONENT)
      ) {
        current = null
        return vnode
      }
      // 省略其他代码...
      return vnode
    }
  }
}

从代码看出,KeepAlive是通过 Composition API 实现,KeepAlive的实现是通过拿到子节点(const children = slots.default()),获取第一个子节点的值(let vnode = children[0] ),存在多个子节点的时候,keepAlive组件不生效了,直接返回。

总结

本篇文章主要了解KeepAlive 实际上是一个抽象节点,渲染的是它的第一个子节点,下一篇文章将讲述了解它的缓存设计、Props 设计和卸载过程。

本文参与 腾讯云自媒体分享计划,分享自作者个人站点/博客。
原始发表:2023-10-26,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • KeepAlive是什么
  • KeepAlive组件的实现需要渲染器的支持
  • 缓存机制
  • 缓存实现
  • 总结
相关产品与服务
容器服务
腾讯云容器服务(Tencent Kubernetes Engine, TKE)基于原生 kubernetes 提供以容器为核心的、高度可扩展的高性能容器管理服务,覆盖 Serverless、边缘计算、分布式云等多种业务部署场景,业内首创单个集群兼容多种计算节点的容器资源管理模式。同时产品作为云原生 Finops 领先布道者,主导开源项目Crane,全面助力客户实现资源优化、成本控制。
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档