JS每日一题: vue中keepalive怎么理解?

Posted JS每日一题

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了JS每日一题: vue中keepalive怎么理解?相关的知识,希望对你有一定的参考价值。

20190212问

vue中keepalive怎么理解?

说在前面: keep-alive是vue源码中实现的一个组件, 感兴趣的可以研究源码 https://github.com/vuejs/vue/blob/dev/src/core/components/keep-alive.js

什么是keepalive

我们平时开发中, 总有部分组件没有必要多次init, 我们需要将组件进行持久化,使组件状态维持不变,在下一次展示时, 也不会进行重新init

keepalive音译过来就是保持活着, 所以在vue中我们可以使用keepalive来进行组件缓存

基本使用

 
   
   
 
  1. // 被keepalive包含的组件会被进行缓存

  2. <keep-alive>

  3.    <component />

  4. </keep-alive>

上面提到被keepalive包含的组件不会被再次init,也就意味着不会重走生命周期函数, 但是平常工作中很多业务场景是希望我们缓存的组件在再次渲染的能做一些事情,vue为keepalive提供了两个额外的hook

  • activated 当keepalive包含的组件再次渲染的时候触发

  • deactivated 当keepalive包含的组件销毁的时候触发

注: 2.1.0 版本后keepalive包含但被exclude排除的组件不会有以上两个hook

参数

keepalive可以接收3个属性做为参数进行匹配对应的组件进行缓存

  • include 包含的组件

  • exclude 排除的组件

  • max 缓存组件的最大值

其中include,exclude可以为字符,数组,以及正则表达式
max 类型为字符或者数字

代码理解

 
   
   
 
  1. // 只缓存组件name为a或者b的组件

  2. <keep-alive include="a,b">

  3.  <component :is="currentView" />

  4. </keep-alive>


  5. // 组件名为c的组件不缓存

  6. <keep-alive exclude="c">

  7.  <component :is="currentView"/>

  8. </keep-alive>


  9. // 如果同时使用include,exclude,那么exclude优先于include, 下面的例子也就是只缓存a组件

  10. <keep-alive include="a,b" exclude="b">

  11.  <component :is="currentView"/>

  12. </keep-alive>


  13. // 如果缓存的组件超过了max设定的值5,那么将删除第一个缓存的组件

  14. <keep-alive exclude="c" max="5">

  15.  <component :is="currentView"/>

  16. </keep-alive>

配合router使用
 
   
   
 
  1. <!-- template -->

  2. // 意思就是$router.meta.keepAlive值为真是将组件进行缓存

  3. <keep-alive>

  4.    <router-view v-if="$router.meta.keepAlive"></router-view>

  5. </keep-alive>

  6. <router-view v-if="!$router.meta.keepAlive"></router-view>


  7. //router配置

  8. new Router({

  9.    routes: [

  10.        {

  11.            name: 'a',

  12.            path: '/a',

  13.            component: A,

  14.            meta: {

  15.                keepAlive: true

  16.            }

  17.        },

  18.        {

  19.            name: 'b',

  20.            path: '/b',

  21.            component: B

  22.        }

  23.    ]

  24. })

总结

keepalive是一个抽象组件,缓存vnode,缓存的组件不会被mounted,为此提供activated 和 deactivated 钩子函数, 使用props max 可以控制缓存组件个数

最近答题



基友噢如果喜欢,可以分享给好基友噢如果喜欢,可以分享给好基友噢

关注「JS每日一题」,参与答题

以上是关于JS每日一题: vue中keepalive怎么理解?的主要内容,如果未能解决你的问题,请参考以下文章

vue中keepalive怎么理解??---vue中文社区

每日一题之vue渲染大量数据应该怎么优化

JS每日一题: 如何理解react中setState?

JS每日一题: react 中的高阶组件理解?

爱创课堂每日一题第五十六天-对前端界面工程师这个职位是怎么样理解的?它的前景会怎么样?

vue中路由的动态keepAlive