vue组件 keep-alive

关注我的个人博客:https://pinbolei.cn,获取更多内容

keep-alive适用于动态组件中,当在组件之间切换的时候,你有时会想保持这些组件的状态,以避免反复重渲染导致的性能问题。

keep-alive让组件实例能够被在它们第一次被创建的时候缓存下来。

注意这个 要求被切换到的组件都有自己的名字,不论是通过组件的 name 选项还是局部/全局注册。

Props:

include - 字符串或正则表达式。只有名称匹配的组件会被缓存。
exclude - 字符串或正则表达式。任何名称匹配的组件都不会被缓存。
max - 数字。最多可以缓存多少组件实例。

用法:

包裹动态组件时,会缓存不活动的组件实例,而不是销毁它们。
是一个抽象组件:它自身不会渲染一个 DOM 元素,也不会出现在父组件链中。
当组件在 内被切换,它的 activateddeactivated 这两个生命周期钩子函数将会被对应执行。

示例:

主要用于保留组件状态或避免重新渲染。



  


 

  
  




  
    
  

include and exclude

includeexclude属性允许组件有条件地缓存。二者都可以用逗号分隔字符串、正则表达式或一个数组来表示:



  




  




  

具体示例:

一个简单的tab切换,可以尝试把去掉之后,对比一下,然后就会发现它的好处。

test.vue






test1.vue




test2.vue




运行代码,打开控制台,你会更直观的看到keep-alive的作用,以及activateddeactivated这两个函数被触发的时间

用setTimeout模拟请求后端接口

1.刚打开页面:


图1

2.点击标题二

图2

3.再次点击标题一,你会发现信息会快速显示出来:

图3

上述示例代码原引用作者 funnycoderstar,链接https://juejin.im/post/5ad56d86518825556534ff4b

以上是添加了keep-alive的情况下,如果去掉keep-alive,每次切换tab你会发现都会重新请求一次数据,感兴趣的可以尝试一下。

:匹配首先检查组件自身的 name 选项,如果 name 选项不可用,则匹配它的局部注册名称 (父组件 components 选项的键值)。匿名组件不能被匹配。

max

最多可以缓存多少组件实例。一旦这个数字达到了,在新实例被创建之前,已缓存组件中最久没有被访问的实例会被销毁掉。


  

你可能感兴趣的:(vue组件 keep-alive)