【Vuejs】1156- 聊聊vue中的keep-alive

共 8045字,需浏览 17分钟

 ·

2021-12-01 12:17

大前端  前端知识宝库  坚持日更

一、什么是keep-alive?

官方介绍就是: 包裹动态组件时,会缓存不活动的组件实例,而不是销毁它们。和  相似, 是一个抽象组件:它自身不会渲染一个 DOM 元素,也不会出现在组件的父组件链中。

当组件在  内被切换时,它的 mounted 和 unmounted 生命周期钩子不会被调用,取而代之的是 activated 和 deactivated

简单理解就是说我们可以把一些不常变动的组件或者需要缓存的组件用包裹起来,这样就会帮我们把组件保存在内存中,而不是直接的销毁,这样做可以保留组件的状态或避免多次重新渲染,以提高页面性能

二、使用用法

我们先根据官方文档来回顾一下组件的具体用法,如下:

组件可接收三个属性:

  • Props:
    • include - string | RegExp | Array。只有名称匹配的组件会被缓存。
    • exclude - string | RegExp | Array。任何名称匹配的组件都不会被缓存。
    • max - number | string。最多可以缓存多少组件实例。
  • 用法:

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

  
  <keep-alive include="a,b">
    <component :is="view">component>

  keep-alive>
  
  
  <keep-alive :include="/a|b/">
    <component :is="view">component>

  keep-alive>
  
  
  <keep-alive :include="['a', 'b']">
    <component :is="view">component>

  keep-alive>

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

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


  <keep-alive :max="10">
    <component :is="view">component>
  keep-alive>

在这里简单介绍一个日常项目中有可能出现的场景并使用keep-alive来实现按需控制缓存 场景:当我们从首页–>列表页–>商品详情页–>返回到列表页(需要缓存)–>返回到首页(需要缓存)–>再次进入列表页(不需要缓存)

  1. 在路由meta对象里定义两个值:

    keepAlive:这个路由是否需要缓存

    deepth:代表页面之间的前进后退的层级关系

   
   {
       path'*',
       name'Home',
       component() => import(/* webpackPreload: true */ '@/views/home'),
       meta: {
         keepAlivetrue,
         deepth1
       }
     },
     {
       path'/list',
       name'list',
       component() => import('@/views/list'),
       meta: {
         keepAlivetrue,
         deepth2
       }
     },
     {
       path'/detail',
       name'Detail',
       component() => import('@/views/detail'),
       meta: {
         keepAlivetrue,
         deepth3
       }
     },
     
  1. 监听路由动态控制需要缓存的值
   //3x版本router-view不允许直接写在keep-alive里面,需注意