vue中keep-alive以及activated,deactivated生命周期的用法

keep-alive以及activated,deactivated生命周期的用法

这是在网上看到的一篇文章

vue官网的描述:

包裹动态组件时,会缓存不活动的组件实例,而不是销毁它们。和 < transition> 相似, 是一个抽象组件:它自身不会渲染一个 DOM 元素,也不会出现在父组件链中。
当组件在 内被切换,它的 activated 和 deactivated 这两个生命周期钩子函数将会被对应执行, 页面第一次进入,钩子的触发顺序created-> mounted-> activated,退出时触发deactivated。

使用例子说明起来更好理解:
先定义两个组件
组件a内容:
在这里插入图片描述
组件b内容:
在这里插入图片描述
父组件内容:
在这里插入图片描述
界面如下:
在这里插入图片描述
我们点击按钮a切换到a组件,可以看到created和activated执行了。然后我们把a组件的show切换成hide,在进行组件切换。
在这里插入图片描述
效果如下:
可以看到离开的A组件的时候deactivated执行了(每次离开当前组件都会执行),再切换回来activated执行了(activated每次切换回来都会执行)、created没有执行(因为组件是缓存并不是销毁,所以created只会执行一次)。而且我们在组件切换之前改的hide,切换回来还是hide,这样就能一直保存组件的状态了。
在这里插入图片描述

  • 1
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值