vue3中keep-alive和vue-router的结合使用方式

前言

  • keep-alive:Vue内置的一个组件,可以使被包含的组件保留状态,或避免重新渲染。
  • router-view:vue-router内置组件, 如果直接包含在keep-alive里面,所有路径匹配到的组件都会被缓存。

提示:以下是本篇文章正文内容,下面案例可供参考

代码

Hmoe组件:



About组件:



路由代码:


一、为何要使用keep-alive?

当路由切换时想要达到页面不重新缓存,避免组件被销毁时即可使用keep-alive来实现。

例如:

vue3中keep-alive和vue-router的结合使用方式_第1张图片

此时切换到“About”组件后“Home”逐渐将会被销毁,

vue3中keep-alive和vue-router的结合使用方式_第2张图片

再切换回“Home”组件时输入框内信息已经被重新渲染消去。

为避免组件重新渲染所以使用“keep-alive”。

二、vue2中使用keep-alive

将“router-view”组件包含于“keep-alive”即可


      

此时组件将保留状态,或避免重新渲染。

三、vue3中使用keep-alive

vue3的keep-alive应用相对于vue2有所变化,此处描述vue3时如何使用,详情可见:Vue Router文档

使


      

改变为如下代码,


  
    
      
    
  

即可。

四、keep-alive属性“include,exclude”的使用

注意:使用include,exclude 属性需要给所有vue类的name赋值,否则 include,exclude将不生效

  • include 值为字符串或者正则表达式匹配的组件name不会被销毁。
  • exclude 值为字符串或正则表达式匹配的组件name会被销毁。

如,修改路由代码为:


例如:

进入页面

vue3中keep-alive和vue-router的结合使用方式_第3张图片

切换路由至“About”

vue3中keep-alive和vue-router的结合使用方式_第4张图片

“Home”组件未被销毁,再切换路由至“Home”

vue3中keep-alive和vue-router的结合使用方式_第5张图片

“About”组件被销毁

以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。

你可能感兴趣的:(vue3中keep-alive和vue-router的结合使用方式)