Vue项目中的keepAlive怎么使用
这篇“Vue项目中的keepAlive怎么使用”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“Vue项目中的keepAlive怎么使用”文章吧。
keepAlive的使用
在开发的过程中如果碰到经常浏览需要缓存的页面,而且页面很长需要记录滚动的位置这时就需要用到keepAlive。
一共有三个步骤
首先在路由中的mate属性中记录keepAlive,如果需要缓存则置为true。
path:'/index',name:''index',component:()=>import('../../index/index'),meta:{keepAlive:true}
在创建router实例的时候加上scrollBehavior方法(keepAlive才会生效)。
let router=new Router({ mode:"hash",//1、hash哈希:有#号。2、history历史:没有#号 base:process.env.BASE_URL, //自动获取根目录路径 scrollBehavior:(to,from,position)=>{ if(position){ return position }else{ return {x:0,y:0} } },
需要缓存的router-view包上keep-alive(要有两个router-view,一个是缓存的时候显示,一个是不缓存的时候显示,有的时候不需要缓存)。
<keep-alive> <router-view v-if="$router.meta.keepAlive"></router-view></keep-alive> <router-view v-if="!$router.meta.keepAlive"></router-view>
注意
在keep-alive中的组件会有两个生命周期的钩子函数,activated和deactivated,其中activated是在组件第一次渲染时会被调用,而且之后每次缓存组件被激活都会被调用。所以一般使用时需要里面的代码和created函数中的代码一样即可。
keepAlive的注意事项
问题描述
今天在测试提到了一个bug,当重复进入相同的组建的时候,mounted和created内的方法不触发,导致页面展示不一样
原因
<keep-alive> 包裹动态组件时,会缓存不活动的组件实例,而不是销毁它们。和 <transition> 相似,<keep-alive> 是一个抽象组件:它自身不会渲染一个 DOM 元素,也不会出现在父组件链中。(所以不会触发mounted和created事件钩子)
当组件在 <keep-alive> 内被切换,它的 activated (激活)和 deactivated (不激活)这两个生命周期钩子函数将会被对应执行。
include and exclude
include (缓存的文件)和 exclude(不换存文件) 属性允许组件有条件地缓存。
<!-- 逗号分隔字符串 --><keep-alive include="a,b"> <component :is="view"></component></keep-alive> <!-- 正则表达式 (使用 `v-bind`) --><keep-alive :include="/a|b/"> <component :is="view"></component></keep-alive> <!-- 数组 (使用 `v-bind`) --><keep-alive :include="['a', 'b']"> <component :is="view"></component></keep-alive>
max
最多可以缓存多少组件实例。
<keep-alive :max="10"> <component :is="view"></component></keep-alive>
以上就是关于“Vue项目中的keepAlive怎么使用”这篇文章的内容,相信大家都有了一定的了解,希望小编分享的内容对大家有帮助,若想了解更多相关的知识内容,请关注编程网行业资讯频道。
免责声明:
① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。
② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341