详解Vue中keep-alive的使用
April Gemini 人气:0前言
keep-alive 是 Vue 的内置组件,当它包裹动态组件时,会缓存不活动的组件实例,而不是销毁它们。例如:在开发中经常有从列表跳到详情页,然后返回详情页的时候需要缓存列表页的状态(比如滚动位置信息),这个时候就需要保存状态,要缓存状态。在组件切换过程中将状态保留在内存中,防止重复渲染DOM,减少加载时间及性能消耗,提高用户体验性。使用方式为
<keep-alive> <component /> </keep-alive>
这里的component会被缓存。
1、概念:
keep-alive是Vue的内置组件,当它包裹动态组件时,会缓存不活动的组件实例,而不是销毁。
2、作用:
用来缓存组件,避免多次加载相同的组件,减少性能消耗,提高用户体验。
3、使用方式:
方式一:在App.vue中使用keep-alive标签,表示缓存所有页面
<div id="app"> <keep-alive> <tar-bar></tar-bar> <div class="container"> <left-menu></left-menu> <Main /> </div> </keep-alive> </div>
方式二:按条件缓存,使用include,exclude判断是否缓存
// 1. 将缓存 name 为 cc 的组件,如果有多个,可用逗号分 <keep-alive include='cc'> <router-view/> </keep-alive> // 2. 将不缓存 name 为 cc 的组件 <keep-alive exclude='cc'> <router-view/> </keep-alive> // 3. 还可使用属性绑定动态判断 <keep-alive :include='includedComs'> <router-view/> </keep-alive>
方式三:在router目录下的index.js中,
第一步:使用meta:{keepAlive = true },表示需要缓存
const routes = [ { path:'/', component:Home, meta:{ keepalive:true } }, { path:'/login', component:Login }, { path:'/edit', component:Edit, meta:{ istoken: true } }, { path:'/home', component:Home, meta:{ keepalive:true } } ]
- 第二步:在App.vue中进行判断
<div id="app"> <!--keep-alive 表示页面不会被销毁,即保持页面状态--> <keep-alive> <router-view v-if="$route.meta.keepalive"></router-view> </keep-alive> <router-view v-if="!$route.meta.keepalive"></router-view> </div>
加载全部内容