JS逐日一题:vue中keepalive怎样明白?

20190212问

vue中keepalive怎样明白?

说在前面: keep-alive是vue源码中完成的一个组件, 感兴趣的能够研讨源码
https://github.com/vuejs/vue/…

什么是keepalive

我们日常平凡开辟中, 总有部份组件没有必要屡次init, 我们需要将组件举行耐久化,使组件状况坚持稳定,鄙人一次展现时, 也不会举行从新init

keepalive音译过来就是坚持在世, 所以在vue中我们能够运用keepalive来举行组件缓存

基础运用

// 被keepalive包括的组件会被举行缓存
<keep-alive>
    <component />
</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 范例为字符或许数字

代码明白

// 只缓存组件name为a或许b的组件
<keep-alive include="a,b"> 
  <component :is="currentView" />
</keep-alive>

// 组件名为c的组件不缓存
<keep-alive exclude="c"> 
  <component :is="currentView"/>
</keep-alive>

// 假如同时运用include,exclude,那末exclude优先于include, 下面的例子也就是只缓存a组件
<keep-alive include="a,b" exclude="b"> 
  <component :is="currentView"/>
</keep-alive>

// 假如缓存的组件超过了max设定的值5,那末将删除第一个缓存的组件
<keep-alive exclude="c" max="5"> 
  <component :is="currentView"/>
</keep-alive>
合营router运用
<!-- template -->
// 意义就是$router.meta.keepAlive值为真是将组件举行缓存
<keep-alive>
    <router-view v-if="$router.meta.keepAlive"></router-view>
</keep-alive>
<router-view v-if="!$router.meta.keepAlive"></router-view>

//router设置
new Router({
    routes: [
        {
            name: 'a',
            path: '/a',
            component: A,
            meta: {
                keepAlive: true
            }
        },
        {
            name: 'b',
            path: '/b',
            component: B
        }
    ]
})

总结

keepalive是一个笼统组件,缓存vnode,缓存的组件不会被mounted,为此供应activated 和 deactivated 钩子函数, 运用props max 能够掌握缓存组件个数

关于JS逐日一题

JS逐日一题能够看成是一个语音答题社区
天天应用碎片时候采纳60秒内的语音情势来完成当天的考题
群主在越日0点推送当天的参考答案

  • 注 毫不仅限于完成当天使命,更多是查漏补缺,进修群内别的同砚优异的答题思绪

点击到场答题

    原文作者:febobo
    原文地址: https://segmentfault.com/a/1190000018147155
    本文转自网络文章,转载此文章仅为分享知识,如有侵权,请联系博主进行删除。
点赞