keep-alive使用场景

本文详细介绍了Vue中的keep-alive组件的使用,包括基础使用、生命周期钩子、与router-view的配合、2.1.0版本后的变化,以及使用时的注意事项。keep-alive可以用于组件状态的持久化,避免不必要的重新渲染。文章通过实例讲解了如何在不同场景下合理利用keep-alive,包括include和exclude属性的运用,以及在动态路由中的缓存策略。
摘要由CSDN通过智能技术生成

Vue中keep-alive的深入理解与使用(配合router-view缓存整个路由页面)
在搭建 vue 项目时,有某些组件没必要多次渲染,所以需要将组件在内存中进行‘持久化’,此时 便可以派上用场了。 可以使被包含的组件状态维持不变,即便是组件切换了,其内的状态依旧维持在内存之中。在下一次显示时,也不会重现渲染。

PS: 与 相似,只是一个抽象组件,它不会在DOM树中渲染(真实或者虚拟都不会),也不在父组件链中存在,比如:你永远在 this.$parent 中找不到 keep-alive 。

1.keep-alive的基础使用

最基础的一般是结合动态组件去使用:
javascript 代码

<keep-alive>
    <component :is="currentView"></component>
</keep-alive>
new Vue({
    el: '#app',
    data(){
        return {
            currentView: Test //Test为引入的子组件
        }
    }
})

不过此种方式并无太大的实用意义。

2.生命周期钩子

被包含在 中创建的组件,会多出两个生命周期的钩子: activated 与 deactivated

activated
在组件被激活时调用,在组件第一次渲染时也会被调用,之后每次keep-alive激活时被调用。

deactivated
在组件被停用时调用。

注意:只有组件被 keep-alive 包裹时,这两个生命周期才会被

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值